Работа с SQL. Шаблон общего модуля

21.10.21

Разработка - Запросы

Шаблон общего модуля для работы с MS/PG SQL из 1С.

В одной из последних задач появилась надобность в запросах к SQL базам из 1С. Для этого был написан общий модуль, код из которого предлагаю ниже. 

Думаю, для кого то это может быть не плохим подспорьем в выполнении схожих задач. Критика и моральные унижения приветствуются. 

 

Основные функции:

Запрос в СУБД

СоздатьДанныеДляПодключения - конструктор данных для подключения к бд. Сюда передаются логин, пароль и т.д. Используется в НовоеСоединениеССУБД.

НовоеСоединениеССУБД - создает соединение с бд COMОбъект("ADODB.Connection").

ВыполнитьЗапрос - выполняет запрос и возвращает результат типа COMОбъект.

ПолучитьРезультатЗапроса - выполняет запрос и возвращает результат типа Таблица значений.

ВыполнитьЗапросВ_Personnel - пример запроса к бд.

ЗакрытьСоединениеССУБД - закрывает соединение с бд.

СоздатьПараметрЗапроса - создает параметры для передачи в запрос. Используется в ВыполнитьЗапрос и ПолучитьРезультатЗапроса, передается в данные функции в виде результата выполнения СоздатьПараметрЗапроса, либо, для передачи нескольких параметров, массив с результатами выполнения СоздатьПараметрЗапроса. По умолчанию тип 12, что позволяет MS SQL самой попытаться подобрать тип передаваемого параметра. В самом запросе параметры указываются как "?", подставляются попорядку добавления.

ВСтрокуBase64 - Используется для типа данных "adLongVarBinary 205 Long binary value", на пример, для получения данных типа image sql в формате Base64. В примере ниже используется для получения изображения из бд.

 

Конструкторы запроса

ЗапросДелет - конструктор запроса для удаления данных из бд. Для страховки, по умолчанию условия установлено в ложь. Пример использования есть ниже.

ЗапросИнсерт - конструктор запроса для добавления данных из бд. Пример использования есть ниже.

ЗапросДобавитьИлиОбновить_My_MS_SQL ЗапросДобавитьИлиОбновить_Pg_SQL - конструктор запроса для добавления, или обновления данных данных из бд. Пример использования есть ниже.

ФорматЧисла ФорматБулевоPG ФорматДатыВремяPGФорматДатыPG ФорматВремяPG ВСтроку - функции форматирования данных для SQL запросов.

 

 
 Код модуля

 

Примеры использования

 
 Получений данных из MS SQL

 

SQLЗапрос = "
| SELECT TOP (1) [Photo]
| FROM [Personnel].[dbo].[tblPersons]
| Where [PFR_Nom] = ? and not [Photo] is null
| order by [Person_Id] desc";
		
ПараметрыЗапроса = Новый Массив();
ПараметрыЗапроса.Добавить(КОРВ_РаботаСБазамиSQL.СоздатьПараметрЗапроса("PFR_Nom",,,"123456789"));
		
Фото = КОРВ_РаботаСБазамиSQL.ВыполнитьЗапросВ_Personnel(SQLЗапрос, ПараметрыЗапроса);
		
Если Фото <> Неопределено и Фото.Количество() > 0 Тогда
	КартинкаBase64 = КОРВ_РаботаСБазамиSQL.ВСтрокуBase64(Фото[0].Photo); //Получаю фото в Base64 для дальнейшей обработки	
КонецЕсли;

 

 

 
 Запись данных в PostgreSQL

 

 
Добавить, или обновить записи в PostgreSQL при записи регистра сведений

 

 
 Удалить данный из SQL

 

Запрос SQL Общий модуль MSSQL PostgreSQL

См. также

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта Платформа 1С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

15500 руб.

02.09.2020    184197    1024    403    

967

Обновление 1С Запросы Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 Абонемент ($m)

Данный инструмент помогает анализировать доработанную конфигурацию после обновления на новый релиз и находить «битые» тексты запросов, в которых участвуют несуществующие в новом релизе метаданные.

2 стартмани

06.02.2025    2174    17    XilDen    26    

36

Запросы Программист Платформа 1С v8.3 Запросы 1C:Бухгалтерия Бесплатно (free)

В статье приведена удобная возможность отладки исполняемого запроса динамического списка.

03.12.2024    5681    artemusII    11    

23

Запросы Программист Бесплатно (free)

Увидел cheatsheet по SQL и захотелось нарисовать подобное, но про запросы.

18.10.2024    13090    sergey279    18    

65

Запросы Программист Платформа 1С v8.3 Запросы 1C:Бухгалтерия Бесплатно (free)

Столкнулся с интересной ситуацией, которую хотел бы разобрать, ввиду её неочевидности. Речь пойдёт про использование функции запроса АВТОНОМЕРЗАПИСИ() и проблемы, которые могут возникнуть.

11.10.2024    8180    XilDen    36    

90

СКД Механизмы типовых конфигураций Запросы Программист Платформа 1С v8.3 1С:Зарплата и кадры государственного учреждения 3 1С:Зарплата и Управление Персоналом 3.x Россия Бесплатно (free)

Работая с типовыми отчетами в конфигурациях «Зарплата и управление персоналом, редакция 3», «Зарплата и кадры государственного учреждения, редакция 3» и подобных, в схемах компоновки данных можно встретить конструкции запросов, которые обращаются к некоторым виртуальным таблицам.

20.08.2024    3164    PROSTO-1C    0    

23

Запросы Программист Запросы Бесплатно (free)

Отлаживая взаимодействие с базой данных, мы регулярно сталкиваемся с зависающими или подозрительно долго выполняющимися обращениями, негативно влияющими на производительность. О том, как в PostgreSQL выявить подозрительные запросы, основываясь на доступной о них информации, расскажем в статье.

16.08.2024    10765    user1840182    5    

29
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. SerVer1C 884 21.10.21 11:16 Сейчас в теме
я сижу на линукс. как это использовать?
DrAku1a; Sedaiko; cleaner_it; info1i; +4 Ответить
2. cleaner_it 209 22.10.21 02:42 Сейчас в теме
(1) Никак. Нужно менять способ подключения, передачи параметров, получения и обработки результата. Навскидку - для Postgres можно использовать psql, только не представляю, как передать параметры, и в каком виде будет возвращён результат
DrAku1a; brr; +2 Ответить
3. malikov_pro 1331 22.10.21 02:51 Сейчас в теме
(1) Либо ставить ADODB, либо использовать HTTP обертку для PG PostREST https://infostart.ru/1c/articles/1304354/
DrAku1a; mrChOP93; cleaner_it; Sedaiko; +4 Ответить
Оставьте свое сообщение