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

17.06.11

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

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

Скачать файл

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

Наименование По подписке [?] Купить один файл
Чтение таблиц MySQL.epf
.epf 13,38Kb
308
308 Скачать (1 SM) Купить за 1 850 руб.

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

См. также

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

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

12000 руб.

02.09.2020    172213    964    403    

925

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

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

8400 руб.

20.08.2024    14752    108    46    

108

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

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

22200 руб.

06.10.2023    17377    43    15    

75

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

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

9360 руб.

17.05.2024    27411    96    48    

139

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

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

15000 руб.

10.11.2023    11978    45    33    

67

SALE! %

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

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

4800 3840 руб.

14.01.2013    191407    1153    0    

920

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

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

20000 руб.

07.10.2021    18125    7    32    

42

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

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

3600 руб.

27.12.2024    1166    2    0    

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