仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 1341|回复: 9
打印 上一主题 下一主题

[学习教程] 巧用instead触发器办理存储历程不克不及利用table数据集为参数的成绩 ...

[复制链接]
老尸 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-16 14:07:10 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
用一个库#bak_database存放这些历史数据。存储历程信任人人都已很熟习了,它是不克不及利用数据集为参数的,就是不克不及向它传送一个表数据。假如碰着这类情形,我们只能是使用游标轮回表中的每行数据,在游标中挪用存储历程了。

本章我们讲一下怎样使用instead触发器来一次性处置数据会合一切的数据。

我们都晓得,instead触发器会中止对表的操纵(好比修正,新增,删除等),假如有创立了instead触发器,而该触发器中又未再次显式的对数据举行操纵(修正,新增,删除),那末,这个举措就不会对该表起感化了。使用这一特征,我们可使用它来办理存储历程承受数据集的成绩。

经由过程示例来讲明:
先创立一个存储历程usp_demo,该存储历程承受参数@aint与@bint,在存储过程当中盘算这两个参数的和并将了局拔出光临时表#table:
createprocedureusp_demo
@aint,
@bint
as
declare@cint
set@c=@a+@b
insertinto#table(ID)values(@c)

再创立一时表#table
createtable#table
(
IDint
)

然后我要将数据集
select1asa,2asb
union
select3asa,10asb
union
select4asa,12asb
拔出到表#table中

办法一:经由过程存储历程usp_demo将测试数据拔出到表#table中,处置办法应当是如许的。
declare@aint
declare@bint
declarere_cusorcursorforselect1asa,2asb
union
select3asa,10asb
union
select4asa,12asb

openre_cusor
fetchnextfromre_cusorinto@a,@b
while@@fetch_status=0
begin
execusp_demo@a,@b
fetchnextfromre_cusorinto@a,@b
end

closere_cusor
deallocatere_cusor

下面办法当然完成了功效,但由于用到了游标,这是我们所不想的。上面我们使用instead触发器来完成一样的功效。

办法二:使用instead触发器将测试数据拔出到表#table中
先创立一个表,该表的字段与存储历程的参数一样。
createtableut_demo
(
aint,
bint
)

然后为该表创立instead触发器
createtriggeriti_ut_demoonut_demoinsteadofinsert
as
insertinto#table(ID)
selecta+bfrominserted

如许,触发器iti_ut_demo即中止了对表ut_demo的操纵,又往#table中拔出了数据。我们将数据集
select1asa,2asb
union
select3asa,10asb
union
select4asa,12asb
拔出表#table中的办法为:
insertintout_demo(a,b)
select1asa,2asb
union
select3asa,10asb
union
select4asa,12asb

最初删除测试顶用到的工具:
droptable#table
droptableut_demo
dropprocedureusp_demo


以上办法为团体履历,若有不当的地方看人人在批评中会商。使为了数据安全,我们搭建了主从。但实时主从备份只能防止硬件问题,比如主库的硬盘损坏。但对于误操作,则无能为力。比如在主库误删一张表,或者一个update语句没有指定where条件,导致全表被更新。
飘灵儿 该用户已被删除
沙发
发表于 2015-1-16 15:45:27 | 只看该作者

巧用instead触发器办理存储历程不克不及利用table数据集为参数的成绩 ...

如果处理少量数据,比如几百条记录的数据,我不知道这两种情况哪个效率更高,如果处理大量数据呢?比如有表中有20万条记录.
老尸 该用户已被删除
板凳
 楼主| 发表于 2015-1-18 18:26:01 | 只看该作者
sqlserver的痛苦之处在于有用文档的匮乏,很多只是表明的东西
灵魂腐蚀 该用户已被删除
地板
发表于 2015-1-27 16:18:19 | 只看该作者
如安全管理、备份恢复、性能监控和调优等,SQL只要熟悉基本操作就可以,只要程序设计部分只要稍加了解即可(如存储过程、触发器等)。
精灵巫婆 该用户已被删除
5#
发表于 2015-2-5 14:26:10 | 只看该作者
另一个是把SQL语句写到服务器端,就是所谓的SP(存储过程);
若相依 该用户已被删除
6#
发表于 2015-2-12 06:36:30 | 只看该作者
语句级快照和事务级快照终于为SQLServer的并发性能带来了突破。个人感觉语句级快照大家应该应用。事务级快照,如果是高并发系统还要慎用。如果一个用户总是被提示修改不成功要求重试时,会杀人的!
蒙在股里 该用户已被删除
7#
发表于 2015-3-3 00:59:27 | 只看该作者
你觉得我的非分区索引无法对起子分区,你可以提醒我一下呀!没有任何的提醒,直接就变成了非分区表。不知道这算不算一个bug。大家也可以试试。
活着的死人 该用户已被删除
8#
发表于 2015-3-11 08:51:15 | 只看该作者
你可以简单地认为适合的就是好,不适合就是不好。
深爱那片海 该用户已被删除
9#
发表于 2015-3-18 03:42:12 | 只看该作者
以前的DTS轻盈简单。但是现在的SSIS虽然功能强大了很多,但是总是让人感觉太麻烦。看看论坛中询问SSIS的贴子就知道。做的功能太强大了,往往会有很多用户不会用了
兰色精灵 该用户已被删除
10#
发表于 2015-3-25 12:13:08 | 只看该作者
再开发调试阶段和OLAP环境中,外键是可以建立的。新版本中加入了SETNULL和SETDEFAULT属性,能够提供能好的级联设置。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2025-1-8 11:45

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表