两个SQL Server存储过程,一个触发器

1. 备份日志, 避免日志过快增长 no_log / trancate_only

 

BACKUP LOG realnew_DATA WITH NO_LOG
DBCC SHRINKDATABASE(realnew_DATA ,TRUNCATEONLY)
BACKUP LOG realnew_DATA WITH Truncate_ONLY

BACKUP LOG sjyh WITH NO_LOG
DBCC SHRINKDATABASE(sjyh,TRUNCATEONLY)
BACKUP LOG sjyh WITH Truncate_ONLY

 

 

 

2. 维持历史库数据表中的记录不超过5000条, 并将实时库中数据插入历史库

(1) 使用存储过程 --作业

 

CREATE procedure insert_calHistory as

if ((select count(tag_id) from CalcOUT_1_HIS)>3000)
begin
delete from CalcOUT_1_HIS where tag_id in 
(select top 500 tag_id from CalcOUT_1_HIS order by tag_id)
end
insert into CalcOUT_1_HIS select * from CalcOUT_1_REAL

go

 

 

然后,添加作业

调度:每天每隔3分钟执行一次

 

SQL: exec insert_calHistory

 

 

(2) 使用触发器--针对表一级的

 

CREATE TRIGGER deleterecord ON [dbo].[testtrigger] 
after INSERT 
AS
IF
(SELECT COUNT(*) FROM testtrigger) >5000
BEGIN
DELETE FROM testtrigger where id not in 
( select top 300 id from testtrigger order by id desc)
END
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

martian6125

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值