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

上一篇 / 下一篇  2008-02-26 15:31:00 / 个人分类:数据库技术

 

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

TAG:

 

评分:0

我来说两句

显示全部

:loveliness: :handshake :victory: :funk: :time: :kiss: :call: :hug: :lol :'( :Q :L ;P :$ :P :o :@ :D :( :)

日历

« 2008-10-10  
   1234
567891011
12131415161718
19202122232425
262728293031 

数据统计

  • 访问量: 4610
  • 日志数: 146
  • 建立时间: 2006-12-16
  • 更新时间: 2008-04-07

RSS订阅

Open Toolbar