Скрипт 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    184696    1029    403    

968

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

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

8400 руб.

20.08.2024    24733    163    86    

161

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

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

22200 руб.

06.10.2023    20423    52    19    

86

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

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

15000 руб.

10.11.2023    13732    57    33    

77

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

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

9360 руб.

17.05.2024    30644    105    48    

148

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

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

20000 руб.

07.10.2021    19144    7    32    

43

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

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

5000 руб.

07.02.2018    104938    246    100    

311
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. tormozit 7273 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)

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

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