sqlserver dba日常操作

在SQL Server中,DBA(数据库管理员)的日常操作可能包括以下任务:

  1. 数据库备份和恢复。
  2. 监控性能,处理死锁和长时间运行的查询。
  3. 管理用户权限和安全性。
  4. 优化查询和索引。
  5. 监控磁盘空间和数据库健康状况。
  6. 应用数据库修复和一致性检查。

以下是一些示例SQL脚本,展示了这些操作的基本形式:

  1. 备份数据库:



BACKUP DATABASE [YourDatabase] TO DISK = 'C:\path\YourDatabase.bak'
  1. 恢复数据库:



RESTORE DATABASE [YourDatabase] FROM DISK = 'C:\path\YourDatabase.bak'
  1. 监控死锁:



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
  1. 取消长时间运行的查询:



-- 找到运行时间超过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
  1. 监控磁盘空间:



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
  1. 数据库修复和一致性检查:



-- 修复数据库
DBCC CHECKDB('YourDatabase') WITH NO_INFOMSGS, ALL_ERRORMSGS, NO_WARNINGMSGS
 
-- 修复索引
DBCC REINDEX('YourDatabase')
 
-- 重建索引
DBCC INDEXDEFRAG('YourDatabase')

这些脚本提供了DBA日常操作的基本框架,具体操作时需要根据实际情况调整和增强。

sql
最后修改于:2024年09月04日 21:35

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日