Скрипт MS SQL для вывода информации о дате последнего изменения БД и размере БД. Для всех БД на сервере.

18.11.13

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

Что делает:
Скрипт выводит в виде таблицы информацию о дате последнего изменения базы ( берется из _UsersWorkHistory) и её размер.
Кому нужно:
Может помочь администраторам у которых на сервере множество различных БД 1С.
Одним нажатием кнопки можно понять какие БД стоит рассматривать как "неиспользуемые".

Работает только с базами 8.2 управляемое приложение т.к. для определения даты последнего изменения используется системная таблица:  _UsersWorkHistory

Что делает:
Скрипт выводит в виде таблицы информацию о дате последнего изменения базы ( берется из _UsersWorkHistory) и её размер.
Кому нужно:
Может помочь администраторам у которых на сервере множество различных БД 1С.
Одним нажатием кнопки можно понять какие БД стоит рассматривать как "неиспользуемые".

Так же может использоваться в качестве примера пакетной работы с таблицами, и базами. 

Как работает:

Работает только с базами 8.2 управляемое приложение т.к. для определения даты последнего изменения используется системная таблица: _UsersWorkHistory

При желании можно заменит запрос для определения даты последнего изменения: "Insert into #T1 SELECT '''+ @dbname + ''' as f1, Max(_Date) as f2 FROM ['+ @dbname+'].[dbo].[_UsersWorkHistory]" на ваш. 

Базы не 1С или 1С ниже 8.2 не обрабатываются. 

 

Скрипт: 


print 'Получение информации о размерерах БД'
if object_id('tempdb..#T2') is not null drop table #T2 --Проверим наличие временных таблиц и если существуют удалим.
--Создадим временную таблицу для хранения информации о размерах БД.
create table #T2 (name sysname, db_size nvarchar(13), owner sysname, dbid smallint, created nvarchar(11), status nvarchar(600), compatibility_level tinyint)

insert into #T2 EXEC sp_helpdb --Вызов системной функции и помещение результатов в временную таблицу T2

print 'Получение информации о использовании БД'
if object_id('tempdb..#T1') is not null drop table #T1 --Проверим наличие временных таблиц и если существуют удалим.

--Создадим временную таблицу T1 для хранения информации о последнем измении БД:
--Поля:
-- F1 - Имя базы
-- F2 - Дата последнего изменения.

CREATE TABLE #T1 (f1 sysname, f2 datetime);

-- Выбираем список не системных (database_id>4), активных(state=0) БД
-- Опции LOCAL STATIC READ_ONLY используются для ускорения работы(LOCAL,READ_ONLY) и для того что бы полученная таблица не изменялась в процессе работы(STATIC).
declare dbcursor CURSOR LOCAL STATIC READ_ONLY for SELECT name FROM sys.Databases where database_id>4 and state=0

declare @Count int --Счетчик баз по которым прошел курсор (Используется для отладки что бы видеть что курсор обошел все базы).

declare @dbname sysname --Содержит имя текущей базы данных, используется при работе с курсором.

declare @sqlQuery nvarchar(4000) --Используется для формирования текста запроса (хранит текст запроса).
declare @ParmDefinition nvarchar(500);
declare @CountRow int

OPEN dbcursor
FETCH NEXT FROM dbcursor into @dbname --Устанавливаем @dbname для первой строки набора.

set @count=0 --Устанавливаем начальное значение счетчика (исп. для отладки)

WHILE @@FETCH_STATUS = 0 --Начинаем цикл. @@FETCH_STATUS глобальная переменная для работы с текущим "CURSOR"

BEGIN
--Вывод отладочной информации в консоль.
set @count=@count+1
print @count
print @dbname

--Проверяем есть ли в текущей БД таблица: _UsersWorkHistory (в 8.2 в этой таблице хранится история работы пользователей) .
set @sqlQuery ='select @CountRowOUT = count(*) from ['+@dbname+'].information_schema.tables where TABLE_NAME=''_UsersWorkHistory'''
set @ParmDefinition = '@CountRowOUT int OUTPUT';
exec sp_executesql @sqlQuery, @ParmDefinition, @CountRowOUT=@CountRow OUTPUT

if @CountRow > 0 --Если результат запроса не пустой значит такая таблица есть.
Begin
set @sqlQuery ='Insert into #T1 SELECT '''+ @dbname + ''' as f1, Max(_Date) as f2 FROM ['+ @dbname+'].[dbo].[_UsersWorkHistory]'
exec sp_executesql @sqlQuery
END
ELSE print 'Необработано (8.1 или база шаблона): '+@dbname

FETCH NEXT FROM dbcursor into @dbname
END

CLOSE dbcursor
Deallocate dbcursor

SELECT #T1.*, #T2.*
FROM #T1 LEFT OUTER JOIN
#T2 ON #T1.F1 = #T2.name
order by f2,db_size

Вступайте в нашу телеграмм-группу Инфостарт

См. также

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

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

15500 руб.

02.09.2020    201419    1114    410    

1018

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

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

8400 руб.

20.08.2024    35259    203    104    

194

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

Расширение для создания и редактирования печатных форм в системе 1С:Предприятие 8.3. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и прозрачность разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    23802    63    26    

92

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

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

16000 руб.

10.11.2023    16348    70    39    

88

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

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

9360 руб.

17.05.2024    34493    122    53    

165

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

Инструмент для генерации OpenApi (Swagger) спецификаций на основании файлов конфигураций 1С. Это консольное и десктопное приложение на языке Rust с полноценным редактором кода, содержащим автозамену и подсвечивание ошибок для быстрого и безошибочного написания документирующего комментария.

18000 руб.

22.11.2024    1545    1    0    

8

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

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

6000 руб.

07.02.2018    107057    249    100    

313
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. tormozit 7294 10.04.13 16:37 Сейчас в теме
Еще бы неплохо приделать это к списку баз 1С. Получить все базы из кластера 1С и для каждой вывести такую инфу. У Гилева в облачных сервисах есть похожая фича. Но без облаков она была бы полезнее.
3. VVi3ard 53 10.04.13 16:47 Сейчас в теме
(1) tormozit, это уже нужно обработку писать, вводить логин пароль администратора (я правильно понимаю что под "Список баз 1С" ты имеешь в виду список баз в консоли сервера?)
Я у Гилева не видел того что ты описал, может пропустил, или добавили позже... Надо будет снова подключится посмотреть.
В моем случае просто специфика была такая что баз могло не быть в этом списке.
2. ksvd 10.04.13 16:41 Сейчас в теме
А почему в дате последнего изменения год такой получается?
4013-04-10 16:05:30.000
4. VVi3ard 53 10.04.13 16:48 Сейчас в теме
5. ksvd 10.04.13 16:54 Сейчас в теме
Спасибо за разьяснения и за скрипт.
6. DERL 11.04.13 11:14 Сейчас в теме
2008 выдал такую вещь:

ЗАГОЛОВОК: Microsoft SQL Server Management Studio
------------------------------

Не удается выполнить сценарий.

------------------------------
ДОПОЛНИТЕЛЬНЫЕ СВЕДЕНИЯ:

Не удается запустить отладчик Transact-SQL. Отладчик Transact-SQL не поддерживает SQL Server 2005 и более ранние версии SQL Server. (SQLEditors)

------------------------------
КНОПКИ:

ОК
------------------------------
Показать
Оставьте свое сообщение