Чтение таблицы MySQL в таблицу значений

10.09.19

Разработка - Инструментарий разработчика

Отчет для чтения через ODBC данных любой Таблицы базы MySQL в Таблицу Значений, а также вывод этот таблицы на форму. Для этого есть отдельная функция. Также используется чтение системной таблицы INFORMATION_SCHEMA для получения списка Таблиц в базе данных, или получения Колонок в Таблице. Проверялось на платформе 8.3.13.1513.

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Чтение таблицы MySQL в Таблицу Значений:
.erf 9,72Kb ver:1.0
7
7 Скачать (1 SM) Купить за 1 850 руб.

Пример чтения любой таблицы из баз MySQL через ODBC, а также выгрузка результата в ТЗ и вывода на форму.

Для чтения требуется установка коннектора https://dev.mysql.com/downloads/connector/odbc/5.1.html

Можно использовать, дополнительные параметры к запросу, типа условия по дате и т.п. Все настройки прямо для форме для наглядности. 

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

 

//Пример функции чтения в ТЗ
&НаКлиенте
Функция ПрочитатьТаблицуMySQL(АдресСервера,НомерПорта,ИмяБД,Пользователь,Пароль,ИмяТаблицы,СписокКолонок,ПрямойЗапрос="",Ошибка="",ДопПараметр="")    
    Колонки = СтрокуВМассив(СписокКолонок,","); //Тут список колонок преобразуем в массив
    ТекТЗ = СоздатьТЗ(Колонки); //Создаем ТЗ и добавляем колонки куда будем выгружать
    
    //Само чтение Таблицы из MySQL
    Connection = Новый COMОбъект("ADODB.Connection");    
    Попытка      
        Connection.Open("Driver={MySQL ODBC 5.1 Driver};Server="+СокрЛП(АдресСервера)+";Port="+НомерПорта+";Database="+СокрЛП(ИмяБД)+";User="+СокрЛП(Пользователь)+";Password="+Пароль+";Option=3");        
    Исключение
        Ошибка = "Ошибка подключения - " + ОписаниеОшибки();  
        Возврат ТекТЗ;
    КонецПопытки;    
        
    RS = Новый COMОбъект("ADODB.RecordSet");
    RS.ActiveConnection = Connection;
    Если ЗначениеЗаполнено(ПрямойЗапрос) Тогда
        ТекстЗапросаMySQL = ПрямойЗапрос;
    Иначе    
        ТекстЗапросаMySQL = "SELECT "+СписокКолонок+" FROM "+ИмяТаблицы+" "+ДопПараметр; //+ " WHERE " +ИмяТаблицы+ ".Type = 'Sale';" ;
    КонецЕсли;        
    
    //Сообщить(ТекстЗапросаMySQL);
    
    RS.Open(ТекстЗапросаMySQL);
    RS.MoveFirst(); 
    Пока RS.EOF()=0 Цикл      
        НовСтрока = ТекТЗ.Добавить();
        Для Каждого ТекКолонка из Колонки Цикл
            НовСтрока[ТекКолонка] = RS.Fields(ТекКолонка).Value; //Сообщить(ТекКолонка+"="+НовСтрока[ТекКолонка]);
        КонецЦикла;               
        RS.MoveNext();    
    КонецЦикла; 
    RS.Close();    
      Connection.Close(); 
    Возврат ТекТЗ;
КонецФункции


Функция СоздатьТЗ(Колонки=Неопределено)
	ТекТЗ = Новый ТаблицаЗначений;		
	Если ЗначениеЗаполнено(Колонки) Тогда
		Для Каждого ТекКолонка из Колонки Цикл
			ТекТЗ.Колонки.Добавить(ТекКолонка);
		КонецЦикла;	
	КонецЕсли;
	Возврат ТекТЗ; 
КонецФункции

Функция СтрокуВМассив(Знач Стр, Разделитель=",")
	МассивСтрок = Новый Массив();
	ДлинаРазделителя = СтрДлина(Разделитель);
	Пока 1=1 Цикл
		Поз = Найти(Стр,Разделитель);
		Если Поз=0 Тогда
			МассивСтрок.Добавить(Стр);
			Возврат МассивСтрок;
		КонецЕсли;
		МассивСтрок.Добавить(Лев(Стр,Поз-1));
		Стр = Сред(Стр,Поз+ДлинаРазделителя);
	КонецЦикла;	
	Возврат МассивСтрок;
КонецФункции

 

MySQL обработка чтение таблица запрос ODBC Таблица Значений База sql

См. также

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

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

12000 руб.

02.09.2020    171834    962    403    

924

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку сразу нескольких баз данных и выполнять их автоматически без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    14338    109    46    

108

Пакетная печать Печатные формы Инструментарий разработчика Программист Платформа 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

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

22200 руб.

06.10.2023    17301    43    15    

75

Инструментарий разработчика Программист Платформа 1С v8.3 1C:Бухгалтерия Платные (руб)

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки.

9360 руб.

17.05.2024    27291    96    48    

138

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

Расширение позволяет без изменения кода конфигурации выполнять проверки при вводе данных, скрывать от пользователя недоступные ему данные, выполнять код в обработчиках. Не изменяет данные конфигурации, легко устанавливается практически на любую конфигурацию на управляемых формах.

15000 руб.

10.11.2023    11909    45    27    

67

SALE! %

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

Универсальный инструмент программиста для администрирования конфигураций. Сборник наиболее часто используемых обработок под единым интерфейсом.

4800 3840 руб.

14.01.2013    191255    1152    0    

920

Инструментарий разработчика Программист 8.3.14 Россия Платные (руб)

Расширение для конфигурации “Конвертация данных 3”. Добавляет подсветку синтаксиса, детальную контекстную подсказку, глобальный поиск по коду.

20000 руб.

07.10.2021    18095    7    32    

42

Инструментарий разработчика Платформа 1С v8.3 1C:Бухгалтерия 1С:ERP Управление предприятием 2 Платные (руб)

Разработка Конструктор автоматизированных рабочих мест "Конструктор АРМ" реализована в виде расширения и является универсальным инструментом для создания АРМ любой сложности в пользовательском режиме.

3600 руб.

27.12.2024    1121    2    0    

5
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. kras_71 75 18.04.20 13:57 Сейчас в теме
Хочу уточнить, что не со всеми версиями драйверов ODBC все так просто!
С определенными, возможны танцы с бумнами!!!
К сожалению автор не уточнил, какую конкретную версию драйвера он использовал!
Куда смотрят админы infostart?
Для себя выяснил, методом проб и ошибок, что стабильная версия, которая работает на всех платформах 1С без танцев с бубнами вот эта, а именно 5.6.1!
4. LastRoot 23 19.04.20 16:11 Сейчас в теме
В описании была ссылка на версию 5.1. Если точнее, то mysql-connector-odbc-5.1.13-winx64.msi

На всякий случай прикрепляю их.
Прикрепленные файлы:
mysql-connector-odbc-5.1.13-win32.msi
mysql-connector-odbc-5.1.13-winx64.msi
2. kras_71 75 18.04.20 14:02 Сейчас в теме
И конкретно в моем случае, Бухгалтерия предприятия, редакция 3.0 (3.0.76.67) , не взлетело, так как ТаблицаЗначений не доступна на клиенте!!! В итоге пришлось решать вот так:
RS.MoveFirst(); 
МассивСтрок=Новый Массив;	
Пока RS.EOF()=0 Цикл 
Строка=Новый Структура;
Для А=0 По rs.Fields.Count-1 Цикл
ИмяПоля=RS.Fields(А).Name; 	
Строка.Вставить(ИмяПоля,RS.Fields(А).Value);	
КонецЦикла;	
МассивСтрок.Добавить(Строка);
 RS.MoveNext(); 
КонецЦикла;	
 RS.Close();    
 СоединениеMySQL.Close(); 
Возврат МассивСтрок;
Показать
5. LastRoot 23 19.04.20 16:12 Сейчас в теме
На тонком клиенте ТЗ не доступна, это известная особенность 1С. Попробуйте на толстом клиенте.
3. kras_71 75 18.04.20 14:47 Сейчас в теме
На платформе 1С:Предприятие 8.3 (8.3.16.1063) не работоспособно!!!
Хотя общие принципы, с учетом доработок вполне приемлемы.
6. LastRoot 23 19.04.20 16:14 Сейчас в теме
(3)
На вашей платформе не проверял, в описании написано что "Проверялось на платформе 8.3.13.1513". Спасибо хоть с принципами всё ок :)
Оставьте свое сообщение