Cкрипт для выгрузки DT (детешников) утилитой ibcmd 1С+MSSQL

26.09.22

База данных - Архивирование (backup)

1С+MSSQL Выгрузка информационной базы в файл dt ibcmd infobase dump.

 *.BAT cкрипт выгрузки *.dt файла.

@echo off
chcp 65001
setlocal EnableExtensions EnableDelayedExpansion

rem =============================
rem ====== admin variables ======
rem =============================
rem =========Данные MSSQL========
set user=sa
set pass=*****
set host=SRV1C
rem =========администратор ИБ=====
set user1c=*****
set pass1c=*****
rem =====Путь куда выгружать *.dt файл=====
set BackupDir=E:\backupdt
rem ========Автономный сервер======
set infobasedata=E:\backupdt\infobase

rem =============================
rem === backup all databases ====
rem =============================

set online='ONLINE'
for /F %%a in (' sqlcmd -S%host% -U%user% -P%pass% -Q "SET NOCOUNT ON; SELECT name FROM sys.databases WHERE database_id > 4 AND state_desc = 'ONLINE'" -W -h -1 ') do (
  rem === backup database ====  
C:\"Program files"\1cv8\8.3.20.1674\bin\ibcmd infobase --dbms=mssqlserver --db-server=%host% --db-user=%user% --db-pwd=%pass% --db-name=%%a dump --user=%user1c% --password=%pass1c% "%BackupDir%\%%a\%%a_!DATE:~0,2!!DATE:~3,2!!DATE:~6,4!_!TIME:~0,2!!TIME:~3,2!!TIME:~6,2!.dt" --data=%infobasedata%
 )

Немного по коду 

for /F %%a in (' sqlcmd -S%host% -U%user% -P%pass% -Q "SET NOCOUNT ON; SELECT name FROM sys.databases WHERE database_id > 4 AND state_desc = 'ONLINE'" -W -h -1 ')

Подключаемся к MSSQL, выгружаем подключенные базы (которые в online) и отбрасываем системные базы database_id>4 получаем список 1С баз (при условии, если у нас на MSSQL только базы 1С).

Добавляем скрипт в планировщик заданий windows.

Скрипт планировщик заданий выгрузка информационной базы в файл dt ibcmd infobase

См. также

Архивирование (backup) Журнал регистрации Поиск данных Системный администратор Программист Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 1С:Управление торговлей 11 Платные (руб)

База данных «сама» меняет данные в документах/справочниках? Тогда данный журнал регистрации изменений документов в 1С для Вас! Практически не влияет на скорость записи объектов за счет быстрого алгоритма! Скорость работы почти в 2 раза выше типового механизма «История изменений». Позволяет следить за изменениями и удалением в любых ссылочных объектах конфигурации, с возможностью архивации по HTTP(!) или COM, и сверткой данных. А так же, может восстановить состояние реквизитов (значения) до момента изменения или удаления объекта из базы. Есть ДЕМО-база где можно самостоятельно протестировать часть функционала! Работает на любых платформах выше 8.3.14+ и любых конфигурациях! Версия 3.1 от 24.08.2023!

21600 руб.

15.05.2017    43108    12    24    

40

Архивирование (backup) Инструменты администратора БД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

Данная разработка позволит решить вопрос с резервным копированием Ваших баз в автоматическом режиме, расположенных на сервере 1С. Система умеет ставить блокировки на вход, блокировать фоновые задания, принудительно отключать сеансы пользователей. И все это система делает в автоматически при создании бэкапа (или через команду). Выгрузка происходит в родной формат 1С - .dt. Так же система умеет архивировать данные выгрузки с установкой пароля. Умеет менять расширение файла zip или dt на любое указанное вами, что позволит сохранить выгрузки от шифровальщика. Может удалять старые копии выгрузок, оставляя указанное количество резервных копий, начиная с самой поздней.

6000 руб.

06.11.2012    71316    623    45    

83

Архивирование (backup) Системный администратор Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Программа позволяет выполнять автоматическое создание копий файловых и серверных информационных баз 1С Предприятие 8 и размещение копий в облаке Яндекс.Диск, локальном или сетевом ресурсе.

1200 руб.

03.09.2014    15177    15    6    

21

Архивирование (backup) Администрирование СУБД Системный администратор Россия Бесплатно (free)

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

04.12.2023    7713    n_mezentsev    15    

27

Архивирование (backup) Системный администратор Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

В данной инструкции будет описано, как с помощью pgAdmin, bat-файлов и планировщика заданий Windows организовать резервное копирование, восстановление и хранение копий баз данных.

07.10.2022    23622    sapervodichka    37    

144

Архивирование (backup) Системный администратор Платформа 1С v8.3 Конфигурации 1cv8 Россия Абонемент ($m)

Захотелось клиентам выгрузку архива баз, и выгрузку в дт, готовые скрипты с сети не заработали. Может, кому-то поможет. Релиз 8.3.18.1741.

1 стартмани

25.08.2022    5200    3    Gnom-Gluck    6    

7

Архивирование (backup) Системный администратор Программист Платформа 1С v8.3 Абонемент ($m)

Небольшая утилита для копирования файловых баз данных 1С.

1 стартмани

02.06.2022    4464    3    Giblarium    12    

5
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. SerVer1C 785 26.09.22 11:36 Сейчас в теме
Пользователей надо выгонять из базы ?
2. alex_bob 246 26.09.22 12:55 Сейчас в теме
По-хорошему, релиз платформы тоже надо вынести в параметры.
При релизе < 8.3.20 упадет с ошибкой из-за параметра --data
(1) Не надо, но консистентность после восстановления из такого dt под вопросом.
cleaner_it; user1752096; +2 Ответить
3. ssn5810 80 02.10.22 08:35 Сейчас в теме
можно BackupDir не в отдельные директории для каждой базы, а в одну,
и с возможностью выбора баз ? Спасибо.
4. user1752096 20 02.10.22 20:19 Сейчас в теме
(3)можно, но я только не проверял
@echo off
chcp 65001
setlocal EnableExtensions EnableDelayedExpansion

rem =============================
rem ====== admin variables ======
rem =============================
rem =========Данные MSSQL========
set user=sa
set pass=*****
set host=SRV1C
rem =========администратор ИБ=====
set user1c=*****
set pass1c=*****
rem =====Путь куда выгружать *.dt файл=====
set BackupDir=E:\backupdt
rem ========Автономный сервер======
set infobasedata=E:\backupdt\infobase

rem =============================
rem === backup all databases ====
rem =============================
rem ==="D:\base.txt" список баз==
for /F "usebackq delims=" %%a in ("D:\base.txt") do (
  rem === backup database ====  
C:\"Program files"\1cv8\8.3.20.1674\bin\ibcmd infobase --dbms=mssqlserver --db-server=%host% --db-user=%user% --db-pwd=%pass% --db-name=%%a dump --user=%user1c% --password=%pass1c% "%BackupDir%\%%a_!DATE:~0,2!!DATE:~3,2!!DATE:~6,4!_!TIME:~0,2!!TIME:~3,2!!TIME:~6,2!.dt" --data=%infobasedata%
 )
Показать
Прикрепленные файлы:
backup.zip
5. ssn5810 80 08.10.22 14:04 Сейчас в теме
6. sys1c 17.11.22 03:48 Сейчас в теме
(4) этот скрипт не выгоняет пользователей из баз?
Оставьте свое сообщение