sqlserver dba日常操作
在SQL Server中,DBA(数据库管理员)的日常操作可能包括以下任务:
- 数据库备份和恢复。
- 监控性能,处理死锁和长时间运行的查询。
- 管理用户权限和安全性。
- 优化查询和索引。
- 监控磁盘空间和数据库健康状况。
- 应用数据库修复和一致性检查。
以下是一些示例SQL脚本,展示了这些操作的基本形式:
- 备份数据库:
BACKUP DATABASE [YourDatabase] TO DISK = 'C:\path\YourDatabase.bak'
- 恢复数据库:
RESTORE DATABASE [YourDatabase] FROM DISK = 'C:\path\YourDatabase.bak'
- 监控死锁:
SELECT
t.transaction_id,
t.is_user_transaction,
t.is_local,
t.is_enlisted,
o.object_name
FROM
sys.dm_tran_locks l
JOIN
sys.partitions p ON l.resource_associated_entity_id = p.hobt_id
JOIN
sys.objects o ON p.object_id = o.object_id
JOIN
sys.dm_tran_active_transactions t ON l.requesting_transaction_id = t.transaction_id
- 取消长时间运行的查询:
-- 找到运行时间超过5分钟的查询
SELECT
session_id,
text,
start_time,
current_time = GETDATE()
FROM
sys.dm_exec_requests
CROSS APPLY
sys.dm_exec_sql_text(sql_handle)
WHERE
start_time < DATEADD(MINUTE, -5, GETDATE())
-- 取消这些查询
DECLARE @sql NVARCHAR(MAX)
SELECT @sql = STRING_AGG('KILL ' + CAST(session_id AS NVARCHAR(10)), '; ')
FROM
sys.dm_exec_requests
WHERE
start_time < DATEADD(MINUTE, -5, GETDATE())
EXEC sp_executesql @sql
- 监控磁盘空间:
SELECT
db.name AS 'Database Name',
db.size * 8 / 1024.0 AS 'Data Size (MB)',
ds.unallocated_extent_page_count AS 'Unallocated Space (Pages)',
CAST(ds.unallocated_extent_page_count * 8 AS DECIMAL(10,2)) / 1024.0 AS 'Unallocated Space (MB)'
FROM
sys.master_files mf
JOIN
sys.databases db ON mf.database_id = db.database_id
JOIN
sys.dm_db_file_space_usage ds ON mf.database_id = ds.database_id
- 数据库修复和一致性检查:
-- 修复数据库
DBCC CHECKDB('YourDatabase') WITH NO_INFOMSGS, ALL_ERRORMSGS, NO_WARNINGMSGS
-- 修复索引
DBCC REINDEX('YourDatabase')
-- 重建索引
DBCC INDEXDEFRAG('YourDatabase')
这些脚本提供了DBA日常操作的基本框架,具体操作时需要根据实际情况调整和增强。
评论已关闭