Получение данных таблиц PostgreSQL через внешний источник данных

31.01.22

Интеграция - Внешние источники данных

Получение данных таблиц напрямую из PostgreSQL через объект конфигурации "Внешний источник данных", с развёрнутым сервером 1С на Linux.

Хочу предложить способ прямого получения данных таблиц PostgreSQL из 1С 8, сервер которого развёрнут на Linux.

Была поставлена задача - считать данные произвольных таблиц PostgreSQL и вывести данные таблиц для просмотра пользователю. 

Все, найденные на просторах интернета, способы не подошли, поэтому и пришлось придумать свой способ. Не исключено, что где то этот способ описан, просто плохо искал. В любом случае, поделюсь опытом, может кому то пригодится.

Решил задачу следующим образом:

1. Был создан новый внешний источник данных. На закладке "Функции" была добавлена функция. Пример заполненных значений свойств можно увидеть на рисунке ниже.

 

 

2. Через PgAdmin создана новая функция (здесь -> "имя базы" - Schemas - Public - Functions). В созданной функции указано, что она будет возвращать значение, причём, в формате json. У функции имеется один входящий текстовый параметр, в который будет приходить из 1С произвольный запрос для исполнения. Ниже представлен скрипт создания функции.

CREATE OR REPLACE FUNCTION public.getdatatables(
	text)
    RETURNS SETOF json 
    LANGUAGE 'plpgsql'
    COST 100
    VOLATILE PARALLEL UNSAFE
    ROWS 2

AS $BODY$
BEGIN
    RETURN QUERY EXECUTE $1;
END;    
$BODY$;

ALTER FUNCTION public.getdatatables(text)
    OWNER TO postgres;

3. В 1С 8.3 создана обработка, в которой сначала подключаемся к СУБД PostgreSQL через внешний источник данных

ПараметрыСоединения = Новый ПараметрыСоединенияВнешнегоИсточникаДанных;
ПараметрыСоединения.СтрокаСоединения = "Driver=PostgreSQL_ERP};Server=*********;Port=5432Database=prod_1c_***_****;Uid=postgres;Pwd=*******;STMT=utf8";
ПараметрыСоединения.СУБД             = "PostgreSQL";
ПараметрыСоединения.АутентификацияОС = Ложь;
ПараметрыСоединения.АутентификацияСтандартная              = Истина;
ПараметрыСоединения.ИмяПользователя  = "postgres";
ПараметрыСоединения.Пароль           = "*******";

Попытка
   ВнешниеИсточникиДанных.СУБДPOSTGRES.УстановитьОбщиеПараметрыСоединения(ПараметрыСоединения);
   ВнешниеИсточникиДанных.СУБДPOSTGRES.УстановитьСоединение();
Исключение
   ....
КонецПопытки;

далее посылаем запрос в функцию PostgreSQL

TextQuery = "SELECT json_agg(tabl) FROM (SELECT * FROM """ПроизваольноеИмяТаблицы""") tabl";
ТелоОтвета = ВнешниеИсточникиДанных.СУБДPOSTGRES.public_getdatatables(TextQuery);

затем, преобразуем полученный ответ в объекты массив и структура.

ЧтениеJSON = Новый ЧтениеJSON;
ЧтениеJSON.УстановитьСтроку(ТелоОтвета);
СтруктураВозврата = ПрочитатьJSON(ЧтениеJSON);

А уже дальше как отобразить данные пользователю, сами выбирайте. Лично я "перегнал" JSON в ТаблицуЗначений и через ПостроительОтчета вывожу на форму.

См. также

SALE! 15%

Внешние источники данных Программист Бизнес-аналитик Пользователь Платформа 1С v8.3 Управляемые формы Анализ и прогнозирование Конфигурации 1cv8 Узбекистан Беларусь Кыргызстан Молдова Россия Казахстан Платные (руб)

Готовое решение для автоматической выгрузки данных из 1С 8.3 в базу данных ClickHouse, PostgreSQL или Microsoft SQL для работы с данными 1С в BI-системах. «Экстрактор данных 1С в BI» работает со всеми типовыми и нестандартными конфигурациями 1С 8.3 и упрощает работу бизнес-аналитиков. Благодаря этому решению, специалистам не требуется быть программистами, чтобы легко получать данные из 1С в вашей BI-системе.

28500 руб.

15.11.2022    21224    21    49    

38

Внешние источники данных Зарплата Бюджетный учет Программист Бухгалтер Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и кадры государственного учреждения 3 Государственные, бюджетные структуры Россия Бухгалтерский учет Бюджетный учет Платные (руб)

Обработка позволяет перенести кадровую информацию и данные по заработной плате, фактических удержаниях, НДФЛ, вычетах, страховых взносах из базы Парус 7.хх учреждений (далее Парус) в конфигурацию 1С:Зарплата и кадры государственного учреждения ред. 3 (далее 1С) и начать с ней работать с любого месяца года.

48000 руб.

24.04.2017    51478    102    165    

90

Внешние источники данных Кадровый учет Файловый обмен (TXT, XML, DBF), FTP Перенос данных 1C Программист Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и кадры государственного учреждения 3 Государственные, бюджетные структуры Россия Бухгалтерский учет Бюджетный учет Платные (руб)

Обработка позволяет перенести кадровую информацию и данные по заработной плате, фактических удержаниях, НДФЛ, вычетах, страховых взносах из базы Парус 10 учреждений (далее Парус) в конфигурацию 1С:Зарплата и кадры государственного учреждения ред. 3 (далее 1С) и начать с ней работать с любого месяца года.

60000 руб.

05.10.2022    11061    13    8    

15

Зарплата Внешние источники данных Бюджетный учет Перенос данных 1C Системный администратор Программист Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и кадры государственного учреждения 3 Государственные, бюджетные структуры Россия Бухгалтерский учет Бюджетный учет Платные (руб)

Обработка позволяет перенести кадровую информацию и данные по заработной плате, фактических удержаниях, НДФЛ, вычетах, страховых взносах из базы Парус 8 учреждений (далее Парус) в конфигурацию 1С:Зарплата и кадры государственного учреждения ред. 3 (далее 1С) и начать с ней работать с любого месяца года.

84000 руб.

19.08.2020    25405    22    1    

25

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

Обработка позволяет перенести кадровую информацию и данные по заработной плате, фактических удержаниях, НДФЛ, вычетах, страховых взносах из базы Парус 8 организаций (далее Парус) в конфигурацию 1С:Зарплата и управление персоналом, ред. 3 (далее 1С) и начать с ней работать с любого месяца года.

84000 руб.

07.06.2021    13355    2    3    

3

Внешние источники данных Облачные сервисы, хостинг Программист Бизнес-аналитик Пользователь Руководитель проекта Платформа 1С v8.3 8.3.14 1С:Розница 2 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Бытовые услуги, сервис Розничная и сетевая торговля (FMCG) Оптовая торговля, дистрибуция, логистика Гостиничный бизнес Рестораны, кафе и фаст-фуд Реклама, PR и маркетинг Легкая промышленность, мода и одежда Управленческий учет Платные (руб)

Расширение позволяет автоматизировать управление картами лояльности и взаимодействие с покупателями при помощи интеграции корпоративной системы 1С и специализированного облачного сервиса "CARDPR". Автоматическая онлайн синхронизация сведений о владельце электронной карты лояльности и баланса бонусных баллов на карте между корпоративной системой 1С и мобильным устройством покупателя. Оповещение покупателя об изменении баланса его электронной карты лояльности и проведении каких-либо маркетинговых акций в компании при помощи рассылки push-сообщений на его мобильное устройство.

36000 руб.

20.07.2023    3308    1    2    

12
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. AnnaTilanhem 04.07.22 09:21 Сейчас в теме
Вопрос: а на чём развёрнут сам PostgreSQL?
2. AndreyNit 60 04.07.22 12:44 Сейчас в теме
3. AnnaTilanhem 05.07.22 07:50 Сейчас в теме
(2) А сервер 1С тоже на нём же разворачивали?
4. AndreyNit 60 06.07.22 09:12 Сейчас в теме
Сервер 1С тоже на Astra Linux.
5. EvgeniusRusius 23.03.23 15:53 Сейчас в теме
Просто пускай здесь будет для тех кто гуглит:
Если при получении данных из таблицы "внешнего источника данных" находящиеся в СУБД PostgreSQL получаете ошибку вида:

"Ошибка ODBC. SQLSTATE: 42703
Номер ошибки: 1
Описание: ОШИБКА: столбец t1.<<ваше имя колонки таблицы >> не существует;"

То для каждой колонки таблицы в свойстве "Имя в источнике данных" - оберните имя поля в кавычки.
VKuser56389494; user814744; cdiamond; +3 Ответить
8. user814744 25.01.24 10:58 Сейчас в теме
(5)Спасибо, тебе человечище! полтора дня копался.
6. v25i85 3 14.08.23 10:57 Сейчас в теме
ошибка выводится RETURN LINE 15: RETURN QUERY EXECUTE $1; ^
7. AndreyNit 60 15.08.23 08:11 Сейчас в теме
(6) В параметре $1 должен быть валидный текст запроса.
9. user2074236 28.03.24 18:38 Сейчас в теме
У меня возникла проблема - при подключении к бд в конфигураторе после ввода верной строки соединения и логина с паролем отображается структура базы данных - одни имена таблиц. Никаких полей у этих таблиц не отображается. Если нажать на плюсик около имени таблицы , то он изчезает и никаких полей этой таблицы все-равно не появляется.
10. user2074236 28.03.24 18:43 Сейчас в теме
У меня возникла проблема - при подключении к бд в конфигураторе после ввода верной строки соединения и логина с паролем отображается структура базы данных - одни имена таблиц. Никаких полей у этих таблиц не отображается. Если нажать на плюсик около имени таблицы , то он изчезает и никаких полей этой таблицы все-равно не появляется. 1c и postgresql крутятся на астра линуксе.
11. tankistandrey 13.09.24 17:30 Сейчас в теме
(10) Подскажите, удалось решить проблему?.
Оставьте свое сообщение