Чтение данных из таблиц базы данных (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
298
.epf 13,38Kb 298 Скачать

См. также

Добавить вознаграждение
Комментарии
1. Serj (Serj1C) 458 20.06.11 07:01 Сейчас в теме
Посмотри внешние источники данных в 8.2.14
не придется вызывать ком-объекты, все будет работать на внутренних механизмах 1С.
Запрос можно будет писать конструктором запросов прямо из конфигуратора, затем выгружать данные в таблицу значений через СКД!
2. Артур Аюханов (artbear) 847 20.06.11 09:34 Сейчас в теме
(1) Вроде как этот механизм можно юзать только встроенным в конфигурацию, т.е. на внешних обработках ничего не построишь :(
3. Яков Коган (Yashazz) 1957 21.06.11 16:15 Сейчас в теме
(1) При определённой степени извращённости вроде бы можно скормить СКД набор данных из внешнего источника и до версии 8.2.14, и именно динамически. Нэ?
4. Alex ZZZ (zaleslaw) 22.06.11 14:43 Сейчас в теме
я не могу скачать - он дает мне скачать левый файл с названием Чтение.
Gasdrubal; +1 Ответить
5. Serj (Serj1C) 458 22.06.11 15:02 Сейчас в теме
(3) Через набор данных "Объект"? и инициализировать его таблицей значений? или как?
6. Яков Коган (Yashazz) 1957 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) 26 13.03.12 11:20 Сейчас в теме
добрый день. Нет случайно примера записи и обновления данных в таблице MySql из 1С.
miller-adm; +1 Ответить
11. Дмитрий Фролов (Jivchic) 90 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) 173 31.08.12 20:51 Сейчас в теме
Благодарность автору, помогла обработка
17. Андрей (AKV77) 212 24.09.15 11:46 Сейчас в теме