Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
0 / 0 / 0
Регистрация: 07.04.2015
Сообщений: 29

Скрипт завершения старой транзакции

26.08.2019, 10:39. Показов 2388. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток.

Помогите сделать скрипт в MS SQL

Есть запрос, который выводит информацию по самой старой транзакции в базе данных:

SQL
1
2
3
4
USE db_test
CHECKPOINT;
GO
DBCC OPENTRAN
Вывод запроса:

SQL
1
2
3
4
5
6
7
8
9
Сведения о транзакциях для базы данных "db_test".
 
Самая старая активная транзакция:
    SPID (идентификатор процесса сервера): 132
    UID (идентификатор пользователя) : -1
    Имя: sort_init
    Номер LSN : (9442:1235000:278)
    Время запуска : авг 11 2019  4:09:19:130PM
    Идентификатор безопасности : 0xbc6de5711b55cd49b1c3241df2658d52
Необходим скрипт, который будет из вывода запроса "Время запуска" брать дату и время, сравнивать с текущим, и если транзакция выполняется больше 3-х часов, то убивать ее, подставляя SPID в KILL:

SQL
1
2
KILL 132; 
GO
Заранее спасибо.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
26.08.2019, 10:39
Ответы с готовыми решениями:

Получить ответ от успешного завершения транзакции
Используя Begin ***code** commit В дальнейшем хочу получить ответ, завершилась операция удачно или нет, операясь на не создам...

"Коллекция может быть доступной после завершения транзакции"
Бин А в CMR хранит коллекцию бина В. Я в сервлете читаю эту коллекцию, а при первом к ней обращении возникает ошибка...

Скрипт ожидания завершения процессов
Доброго времени суток, я обычный офисный работник по этому не селен вообще ни в чем, ( сильно не пинайте ), Стоит задача сделать скрипт...

2
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
26.08.2019, 11:31
Лучший ответ Сообщение было отмечено Onigma как решение

Решение

T-SQL
1
2
3
4
5
6
7
8
9
10
declare @t table (property varchar(30), value varchar(100));
 
insert into @t
 exec('dbcc opentran with tableresults;');
 
select
 *
from
 (select cast(value as int) from @t where property = 'OLDACT_SPID') a(spid) cross join
 (select convert(datetime, value) from @t where property = 'OLDACT_STARTTIME') b(starttime);
Остальное доделаете самостоятельно.
1
0 / 0 / 0
Регистрация: 07.04.2015
Сообщений: 29
26.08.2019, 12:48  [ТС]
invm, большое спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
26.08.2019, 12:48
Помогаю со студенческими работами здесь

Как запустить скрипт сразу после завершения?
На сервере стоит ограничение по времени работы скрипта (max_execution_time, или что-то в этом роде) Если скрипт выполняется слишком долго...

Как запустить скрипт по событию завершения работы системы с повышенными правами
Без стороннего ПО. Направление приблизительно ясно: планировщик (только в нем можно с повышенными правами запустить без предупреждения...

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

Транзакции
есть таблица, из двух полей (id - уникальный ключ, идентификатор пользователя и summ - количество денег) Подскажите как правильно...

Транзакции
Есть две таблицы , в первой содержаться имена(Ваня, Андрей, Иван) , во второй их лицевой счет, как сделать так чтобы при изменении лицевого...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru