中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 数据库开发 > 数据库综合
两个sql server存储过程,一个触发器
作者:未知 时间:2005-07-27 23:41 出处:CSDN 责编:chinaitpower
              摘要:两个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


关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有