Подключение к SQL из 1С (обычная и управляемая форма)

20.09.24

База данных - Инструменты администратора БД

Публикация размещена исключительно в образовательных целях и подходит только для платформы версии 8.3.25.1257.
Использует недокументированные средства доступа к базе данных 1С. Прямое обращение к СУБД нарушает лицензионное соглашение,
может изменить поведение платформы, привести к разрушению базы данных, скомпрометировать данные,
а также привести к отказу в официальной поддержке Фирмы 1С.
Обработка позволяет соединиться с SQL-сервером (SQL-авторизация), получить список баз на сервере, после выбора базы - получить список таблиц. Позволяет вывести таблицу на просмотр, при необходимости очистить таблицу средствами SQL (delete from), просмотреть соответствие имен таблиц объектам конфигурации, в которой запущена база. А в случае потери данных таблицы или самой таблицы в рабочей базе можно восстановить через копирование самой таблицы и ее данных из копии базы.

Скачать файл

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

Наименование По подписке [?] Купить один файл
Подключение к SQL из 1С 2.0
.epf 27,25Kb ver:2.0
83
83 Скачать (2 SM) Купить за 2 150 руб.

Предыстория

Ранее рабочая база работала на платформе 8.3.20.1789. Поставили 8.3.25.1257 и начали обновление.

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

Более подробное описание есть в статье Восстановление базы или решение проблемы Ошибка СУБД: Microsoft SQL Server.

Поэтому понадобился функционал копирования таблиц из копии базы.

Обновление выполнялось на 8.3.25.1257 через хранилище конфигурации и в 8.3.25.1374 проблема уже не должна появляться.

 

Описание задачи

Требуется подключиться к копии MS SQL базы на сервере Windows на управляемых формах. Найти список таблиц, которые есть в копии базы, но нету в рабочей базе. Скопировать эти таблицы в рабочую базу. Также можно очистить данные таблиц средствами СУБД.

 

Решение

Было подобрано максимально подходящее решение Просмотр SQL-таблиц из 1С. Возможность очистки таблиц (мои благодарности автору, хоть и посмертно!) и выполнена адаптация под выполняемую задачу.

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

Для поставленной задачи разработана обработка «Подключение к SQL из 1С 2.0» представляет собой полностью автономное решение, с точки зрения встраивания в любую конфигурацию, как на обычных, так и на управляемых формах!

Список основных доработок:

1. Разработана управляемая форма;

2. Разработана функция копирования данных таблиц из копии базы;

3. Улучшен интерфейс;

4. Переработан код.

Обработка поддерживает подключение через дополнительные обработки.

Есть два варианта запуска:

  1. Через меню "Файл - Открыть" как обычную внешнюю обработку.
  2. Через справочник "Дополнительные отчеты и обработки" (в обработку встроен механизм подключения внешних обработок, пример подключения).

Функционал обработки проиллюстрирован в скриншотах.

В коде не используются синхронные и модальные вызовы!

Обработка прошла тестирование в тонком клиенте, толстом клиенте, веб-клиенте, толстом клиенте (обычное приложение) на платформах 8.3.20.1789, 8.3.25.1257, 8.3.25.1374, ОС семейства Windows.

Важно! Перед использованием обработки, сделайте все на копиях баз и не используйте решение для других задач, чтобы не нарушать лицензионное соглашение!

 

Инструкция

Перед использованием нужно заполнить настройки для подключения к СУБД: сервер, имя пользователя и пароль СУБД (желательно создать отдельного или можно использовать системного пользователя - sa).

Нажать кнопку подключения к БД (Соединить/Список БД) - получает список баз СУБД, затем список таблиц первой базы.

Описание кнопок:

1. Кнопка "Просмотр" - показывает данные таблицы в СУБД.

2. Кнопка "Удалить таблицу" - удаляет данные таблицы в СУБД (сделайте резервную копию перед использованием)!

3. Кнопка "Таблицы" - показывает структуру таблиц запущенной базы по формату 1С.

4. Подменю "Копирование данных" - содержит кнопки для работы с данными второй базы - копии.

4.1 Кнопка "Разница таблиц" - получает список разницы таблиц первой (база, которую будем выбирать и откуда будут копироваться данные) и второй базы (база, выбранная на форме, в которую будут копироваться данные.).

4.2 Кнопка "Скопировать выбранную таблицу" - копирует данные таблицы по выбранным строкам из п. 4.1.

4.3 Кнопка "Очистить не выбранное" - удаляет не выбранные строки из п. 4.1 (упрощает визуальное восприятие).

 

Используемый материал

Microsoft SQL Server. Как скопировать таблицу из другой базы

Из ключевого стоит отметить:

Скопировать структуры таблицу и ее данные из одной базы в другую:

SELECT * into [Db2].[dbo].tmp_tbl_Deps FROM [Db1].[dbo].tbl_Deps

Минус у такого решения – не копируются индексы.

P.S. Если материал вам помог, поблагодарите автора, поставив плюс!

Проверено на следующих конфигурациях и релизах:

  • Управление торговлей для Беларуси, редакция 3, релизы 3.5.11.73

Добавил скриншот из переписки.

См. также

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

Расширение «Оперативное проведение» в 4 раза уменьшает время проведения документов и закрытия месяца. Является комплексным решением проблем 62 и 60 счетов. Оптимизирует проведение при включенной функциональной опции «Раздельный учет НДС». Используется в более 10 организациях уже 2 года. Совместимо с конфигурацией Бухгалтерия 3.0 (+КОРП).

14400 руб.

29.04.2020    35881    117    152    

81

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

Обработка для группового редактирования реквизитов номенклатуры в 1С для УТ 11 / КА 2. Позволяет редактировать реквизиты (как основные, так и дополнительные реквизиты и сведения) непосредственно в таблице, устанавливать новые значения реквизитов на выбранную номенклатуру, а также загружать новые значения из Excel. Предусмотрена возможность добавления фото к товарам перетаскиванием файла из проводника на строку с товаром (drag'n'drop)

4200 руб.

16.11.2020    18090    12    6    

11

Корректировка данных Бухгалтер Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Бухгалтерский учет УСН Платные (руб)

Расширение предназначено для корректировки записей в книге доходов и расходов. Пока только для документов: Поступление на расчетный счет, Списание с расчетного счета, Поступление наличных (в народе ПКО) и Выдача наличных (РКО).

2400 руб.

19.11.2019    19163    36    24    

12

SALE! 50%

Зарплата Бюджетный учет Регламентированный учет и отчетность Корректировка данных Бухгалтер Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и кадры государственного учреждения 3 Государственные, бюджетные структуры Россия Бюджетный учет ФОМС, ЕФС Платные (руб)

Новая форма мониторинга заработной платы работников государственных и муниципальных учреждений с автозаполнением и выгрузкой для сдачи по телекоммуникационным каналам связи в Пенсионный Фонд Российской Федерации. Обработка соответствует Поручению Президента РФ от 8 марта 2021 г. №Пр-366, Приказу Правительства РФ по пункту 1 раздела XIII протокола заседания Правительства РФ от 3, 4 марта 2021г. № ТГ-П45-2608 и от 12 марта 2021г. № ТГ-П45-2980.

3600 1800 руб.

22.03.2021    61152    38    539    

42

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

Вы наконец разобрались с закрытием месяцев и пора начать контролировать сроки оплаты поставщикам и задолженности клиентов, но в базе расчеты не идут из-за развернутого сальдо? Не беда, есть решение!

12000 руб.

02.11.2020    7835    5    0    

8

Инструменты администратора БД Программист Пользователь Платформа 1С v8.3 1С:Управление торговлей 11 Россия Абонемент ($m)

У нас часто возникала ситуация, когда необходимо настроить обмен с сайтом или с внешней системой, но выгружаемые изображения слишком сильно увеличивали объем сообщений обмена, обмен происходил медленно. Да и для самой базы, операции с не оптимизированными изображениями требуют большего количество ресурсов и места на диске. Потому мы собрали свои наработки в одно расширение.

5 стартмани

10.07.2020    19961    37    Neti    10    

18

Корректировка данных Программист Управляемые формы 1C:Бухгалтерия Россия Платные (руб)

Универсальный редактор реквизитов для управляемых форм позволяет изменять любые справочники и документы в любых конфигурациях на управляемых формах (8.2 - 8.3). как в толстом клиенте, так и в тонком.

1800 руб.

06.03.2020    18728    23    3    

7
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. SergVolga_34 11 20.09.24 09:53 Сейчас в теме
Когда-нибудь пригодится!)
2. Xershi 1540 20.09.24 11:02 Сейчас в теме
(1) лучше иметь под рукой и никогда не использовать+)))
SergVolga_34; +1 Ответить
3. TMV 11 21.09.24 14:04 Сейчас в теме
вроде там есть нюанс с копированием полей типа timestamp или нет?
4. Xershi 1540 21.09.24 14:45 Сейчас в теме
5. TMV 11 21.09.24 16:14 Сейчас в теме
(4) вот тут
SEL ECT * into [Db2].[dbo].tmp_tbl_Deps FR OM [Db1].[dbo].tbl_Deps
6. Xershi 1540 21.09.24 21:21 Сейчас в теме
(5) единственный нюанс, который там упоминался это индексы. А т.к. применение обработки было в рамках поставленной задачи, то такой вопрос не возникал. Можете провести исследование и более детально посмотреть, что получится.
7. TMV 11 24.09.24 20:23 Сейчас в теме
(6) действительно перепутал с конструкцией
ins ert in to [demo2].[dbo].[Document] sel ect * FR OM [Demo].[dbo].[Document]
8. Оберон 17 27.09.24 15:50 Сейчас в теме
Выгрузить БД на старой платформе и Загрузить БД на новой платформе не судьба конечно было сделать, тем более копия на СУБД была..
ох уж эта религия изобретателей велосипедов: сначала создать проблему и потом творчески ее решать )))
9. Xershi 1540 27.09.24 18:10 Сейчас в теме
(8) почитайте статью внимательнее. Задача более сложная чем вы поняли.
10. Fox-trot 164 02.10.24 09:36 Сейчас в теме
респект.. за кучу восклицательных знаков
Оставьте свое сообщение