gifts2017

Чтение данных из таблиц базы данных (MySQL в частности)

Опубликовал Дмитрий Фролов (Jivchic) в раздел Программирование - Инструментарий

Понадобилось как-то импортировать данные из MySQL в 1С...

Как-то нужно было мне из MySQL импортировать данные в 1С, а опыта импорта данных из баз данных не было...

Сначала пошел путем выгрузки данных в XML с помощью программ, работающих с MySQL и импорт их из XML файлов...
Потом наткнулся на какие-то грабли, и пошел другим путем - импорт данных с помощью MySQL ODBC Driver

Нашел несколько примеров по использованию ADODB (спасибо авторам, чьи разработки использовал для изучения и использования по этому вопросу). Ну и, как обычно, начал переделывать их под свои нужды - что-то добавил, что-то убавил, в результате получилась вполне удобная и простая обработка для чтения данных с помощью ADODB.

Эту обработку в черновом варианте использовал при отладке механизма импорта данных из MySQL, к сожалению, на других базах данных не испытывал. Работал на платформе 8.2, на других не проверял - пока нет возможности.

Для публикации оформил форму в человеческий вид. Хотелось бы поделиться, может кому будет полезно.

Некоторые моменты об обработке:

  • Драйвер (поле): Текст с типом используемого драйвера, я использовал 5.1, у меня проблем с чтением не было, многие предпочитают версию 3.х (скачать можно с оф.сайта http://www.mysql.com/products/connector/)
  • Сервер и порт (поля): расположение MySQL сервера, порт обычно 3306
  • DB Name (поле): имя БД к которой подключаемся
  • Login и Pass (поля): авторизация для подключения к БД

    Поля, указанные выше используются для формирования строки подключения к БД. Различные варианты строк подключения можно найти на сайте connectionstrings.

  • SELECT (текстовое поле со списком): после подключения к БД, выбираются из списка или указываются вручную, поля которые нужно вывести в табличное поле.
  • FROM (текстовое поле со списком): имя таблицы БД из которой выбираем данные
  • WHERE (текстовые поля со списком): указываются условия отбора данных из таблиц
  • Флажки "Учитывать" управляют участием соответствующих условий при отборе данных из таблиц БД
  • Произвольный текст запроса (поле): Используется для написания в ручную SQL запроса, если нужно выполнить запрос из этого поля необходимо поставить флажок "<----" над кнопкой выполнить, это значит что будет выполняться запрос введенный в текстовое поле, при вводе текста в это поле -галочка активируется автоматически (потому как если вы написали запрос и по запарке не поставили галочку "произвольный запрос", нажав кнопку "выполнить" ваш запрос перепишется на запрос из "помощника").
    Также в это поле автоматически, при выполнении запроса с использованием полей "помощника составления запроса", вставляется текст этого запроса. Это сделано для того чтобы можно было корректировать запрос, или использовать его как шаблон для более сложного запроса...

В черновом варианте обработка делала еще некоторые полезности, но они были еще более "черновые", поэтому с этого релиза я их убрал, буду оформлять отдельными обработками, как доделаю...

Можно конечно было сделать текущую обработку еще гибче, но как говориться "совершенству нет предела"...

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


На вопрос: "Зачем еще одна обработка для чтения MySQL, если есть кучу программ для этого MySQL ?" отвечу так:

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


Механизм использования этой обработки зачастую заключался в выполнении SQL-запроса, выгрузке результата в ТаблицуЗначений (ТЗ), а потом уже делаем все что хотим с этой ТЗ...

Скачать файлы

Наименование Файл Версия Размер Кол. Скачив.
Чтение таблиц MySQL.epf
.epf 13,38Kb
17.06.11
295
.epf 13,38Kb 295 Скачать

См. также

Подписаться Добавить вознаграждение

Комментарии

1. Serj (Serj1C) 20.06.11 07:01
Посмотри внешние источники данных в 8.2.14
не придется вызывать ком-объекты, все будет работать на внутренних механизмах 1С.
Запрос можно будет писать конструктором запросов прямо из конфигуратора, затем выгружать данные в таблицу значений через СКД!
2. Артур Аюханов (artbear) 20.06.11 09:34
(1) Вроде как этот механизм можно юзать только встроенным в конфигурацию, т.е. на внешних обработках ничего не построишь :(
3. Яков Коган (Yashazz) 21.06.11 16:15
(1) При определённой степени извращённости вроде бы можно скормить СКД набор данных из внешнего источника и до версии 8.2.14, и именно динамически. Нэ?
4. Alex ZZZ (zaleslaw) 22.06.11 14:43
я не могу скачать - он дает мне скачать левый файл с названием Чтение.
Gasdrubal; +1 Ответить
5. Serj (Serj1C) 22.06.11 15:02
(3) Через набор данных "Объект"? и инициализировать его таблицей значений? или как?
6. Яков Коган (Yashazz) 22.06.11 20:29
(5) Через источник данных СКД с указанием строки соединения. Понятно, что с dbf фокус не пройдёт, и что примеров и документации маловато, но чисто теоретически вроде можно. Интересно, какие значения допустимы для свойства "Тип источника данных"...
7. ULAS SV (ulas) 05.10.11 22:48
жаль,что я не программист, а так было бы очен удобно подключаться к базе данных в ТС
8. игорь тос (svet222) 12.11.11 01:07
10. Сергей Федоров (Bober777) 13.03.12 11:20
добрый день. Нет случайно примера записи и обновления данных в таблице MySql из 1С.
miller-adm; +1 Ответить
11. Дмитрий Фролов (Jivchic) 13.03.12 11:34
пока не готово, были какие-то наброски щас уже и не найду... как будет время -хотел бы добавить такую возможность...
miller-adm; +1 Ответить
12. Viktor Kupko (zipik) 28.08.12 20:06
(1) Serj1C, внешние источники данных сырые еще..там много чего нельзя делать..
13. Viktor Kupko (zipik) 28.08.12 20:06
например нельзя выбрать ПЕРВЫЕ 1
14. Viktor Kupko (zipik) 28.08.12 20:07
заинтересовала обработка.щас сам осваиваю работу с MySQL.скажите в качестве параметра запроса к таблице можно указать таб.значений или массив???
15. Viktor Kupko (zipik) 28.08.12 20:08
16. Александр Журавлев (apostal86) 31.08.12 20:51
Благодарность автору, помогла обработка
17. Андрей (AKV77) 24.09.15 11:46
Для написания сообщения необходимо авторизоваться
Прикрепить файл
Дополнительные параметры ответа