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

Понадобилось как-то импортировать данные из 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-запроса, выгрузке результата в ТаблицуЗначений (ТЗ), а потом уже делаем все что хотим с этой ТЗ…

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *