SQLServer常用技巧

SQL Server占用服务器内存过高

SQL Server对服务器内存的使用策略是用多少内存就占用多少内存,只用在服务器内存不足时,才会释放一点占用的内存,所以SQL Server 服务器内存往往会占用很高。

# 查看内存状态
DBCC MemoryStatus

Sql Server运行时候用作缓存

  • 数据缓存
    执行个查询语句,Sql Server会将相关的数据页(Sql Server操作的数据都是以页为单位的)加载到内存中来, 下一次如果再次请求此页的数据的时候,就无需读取磁盘了,大大提高了速度。
  • 执行命令缓存
    在执行存储过程,自定函数时,Sql Server需要先二进制编译再运行,编译后的结果也会缓存起来, 再次调用时就无需再次编译。

清理缓存命令

# 清除存储过程相关的缓存
DBCC FREEPROCCACHE
# 会话缓存
DBCC FREESESSIONCACHE 
# 系统缓存
DBCC FREESYSTEMCACHE('All') 
# 清除所有缓存
DBCC DROPCLEANBUFFERS 

命令虽然会清除掉现有缓存,为新的缓存腾地方,但是Sql server并不会因此释放掉已经占用的内存。Sql Server并没有提供任何命令允许我们释放不用到的内存。因此我们只能通过动态调整Sql Server可用的物理内存设置来强迫它释放内存。

调整可使用物理内存,把最大服务器内存改成1G,确定后内存就会被强制释放,然后把最大服务器内存改成合适的值。


SQLServer定时器叫做 SQL Server Agent,中文称为 SQL Server代理。

SQLServer定时器位于SQL Server代理>作业

4933701-fdebfbd6b078be8e.png
作业

-- 指定范围生成随机用户编号
DECLARE @randMin BIGINT
DECLARE @randMax BIGINT
SET @randMin = 10000000
SET @randMax = 99999999
SET @UserID = ROUND((@randMax - @randMin - 1)*RAND() + @randMin, 0)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值