SQLServer存储过程和触发器

存储过程即为能完成特定功能的一组SQL语句集。如果需要对查出的多条数据进行操作的话,这里需要理解游标(CURSOR)的概念,对于oracle有for each row命令,可以不用游标。

游标可以理解为一个结果集,描述cursor的关键字有:

SCROLL关键字指明游标可以在任意方向上滚动

FORWARD_ONLY指明游标只能向前滚动。

READ ONLY指明在游标结果集中不允许进行数据修改。

UPDATE关键字指明游标的结果集可以修改。

GLOBAL关键字使得游标对于整个连接全局可见

LOCAL关键字指明游标是局部的,它只能在它所声明的过程中使用。

等等。。。

一般结果集需要遍历,如例,将一些表中的字段查出来,插入到另外一张表中:

例1:查询表数据插入到另外一张表

CREATE PROCEDURE sp_insertIntoTest_hibernate

AS

DECLARE @projectid VARCHAR(20)

DECLARE @projectcode VARCHAR(20)

DECLARE @projectname VARCHAR(100)

DECLARE @projectamount DECIMAL(16,2)

DECLARE @remark VARCHAR(1000)


DECLARE cs CURSOR FOR --定义游标的数据集


SELECT L.PROJECTID,P.CODE,L.PROJECTNAME,L.LEASINGAMOUNT, L.proInfoSummary

FROM LAPROJECT L LEFT JOIN PARTY_CUSTOMER P ON P.ID=L.TENANTID

WHERE (L.TENANTID<>'' AND L.TENANTID IS NOT NULL) ORDER BY L.PROJECTID


BEGIN

DELETE FROM test_hibernate

OPEN cs --打开游标

FETCH NEXT FROM cs INTO @projectid,@projectcode,@projectname,@projectamount,@remark --从游标中取值赋给变量

    WHILE @@FETCH_STATUS = 0 --fetch语句执行成功返回0,fetch语句执行失败或者此行不在结果集中返回-1,被提取的行不存在则返回-2.

        BEGIN

        PRINT '====start insert===='

        INSERT INTO test_hibernate VALUES(@projectid,@projectcode,@projectname,@projectamount,@remark)

        PRINT '==== end  insert===='

        FETCH NEXT FROM cs INTO @projectid,@projectcode,@projectname,@projectamount,@remark --继续取下一行数据

        END

    CLOSE cs --关闭游标

    DEALLOCATE cs --删除游标

END


这个sp起初运行的时候老是报游标已存在问题,时不时还报游标不存在,郁闷。后来修改了下存储过程换了个游标名称就好了,网上查了很多说是游标没关闭没释放或者是关闭释放位置不对等问题,自己实践证明我的问题不是这样的,至今搞不懂是啥原因造成的问题,可能是第一次写sp的时候没释放,后面加上了释放和删除那两句话吧。

例2:分页查询

CREATE PROCEDURE sp_getpermbal 

@pageSize INT,

@page INT

AS

DECLARE @temp INT SET @temp=@pageSize*(@page-1)

BEGIN

SELECT TOP (SELECT @pageSize) * FROM LAPERMBAL

WHERE projectid+contractid+grantid+convert(varchar(20),retsn)+convert(varchar(10),ratebtdt,120) NOT IN

(SELECT TOP (SELECT @temp) projectid+contractid+grantid+convert(varchar(20),retsn)+convert(varchar(10),ratebtdt,120)

FROM LAPERMBAL ORDER BY projectid,contractid,grantid,retsn,ratebtdt DESC)

ORDER BY projectid,contractid,grantid,retsn,ratebtdt DESC

END


 这个查数据需要用到主键,而本例的表使用联合主键,所以进行拼接来识别一条数据的唯一性。


二、触发器(SQLServer)

触发器都说是一种特殊的存储过程,那我也就这么理解了,还挺有道理的、让人比较容易接受的解释。在数据库的表数据有增、删、改的操作时可自动触发的存储过程。

首先理解inserted和deleted两张虚表,看了下oracle相关的内容,应该是用new和old两张虚表,取值可用new.字段名,old.字段名。

新增操作新增的记录存到系统建的虚表inserted中,deleted表无记录;

删除操作删除的记录存到系统建的虚表deleted中,inserted表无记录;

修改操作(分解为先删除再插入)删除的记录存到系统建的虚表deleted中,新增的记录存到inserted表中。

然后就是触发器类型,after触发器和instead of 触发器,这个不理解的可以百度,有很多比我解释的更清楚的大神写的文章。

理解完之后,记录下相关语法:

新建触发器:

例:更新test_hibernate表,则将被更新记录的字段值置为“test success---” 

CREATE TRIGGER test_trigger

ON test_hibernate

FOR UPDATE

AS

DECLARE @projectid VARCHAR(20),@projectcode VARCHAR(20)

DECLARE cs CURSOR local FOR

SELECT projectid,projectcode FROM deleted

BEGIN

OPEN cs

FETCH NEXT FROM cs INTO @projectid,@projectcode

WHILE @@FETCH_STATUS=0

  BEGIN

  UPDATE test_hibernate SET remark='test success---' WHERE projectid=@projectid AND projectcode=@projectcode

  FETCH NEXT FROM cs INTO @projectid,@projectcode

  END

CLOSE cs

DEALLOCATE cs

END

GO

  修改触发器:

ALTER TRIGGER test_trigger 

ON test_hibernate

FOR UPDATE

AS 
......

  禁用、启用触发器:

ALTER TABLE test_hibernate DISABLE TRIGGER test_trigger

ALTER TABLE test_hibernate ENABLE TRIGGER test_trigger


ALTER TABLE test_hibernate DISABLE TRIGGER ALL

ALTER TABLE test_hibernate ENABLE TRIGGER ALL

http://www.cnblogs.com/hoojo/archive/2011/07/20/2111316.html【转载】

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,402评论 6 499
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,377评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,483评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,165评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,176评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,146评论 1 297
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,032评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,896评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,311评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,536评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,696评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,413评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,008评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,659评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,815评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,698评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,592评论 2 353

推荐阅读更多精彩内容

  • 语 句 功 能 数据操作 SELECT——从数据库表中检索数据行和列INSERT——向数据库表添加新数据行DELE...
    戰敭阅读 5,092评论 0 53
  • 一. Java基础部分.................................................
    wy_sure阅读 3,810评论 0 11
  • 1.创建一个简单的储存过程getallstudentinfor,用于获取所有的学生信息Create Functio...
    五长生阅读 911评论 0 0
  • 易效能® 实践班100天 【周检视】 第二周20170528~20170603 伊蓝~ 听再多、反复听都没用,只有...
    伊蓝_3b35阅读 162评论 0 0
  • 我叫白变净呵呵名字有点搞笑 朋友都称呼我老白 来自一个很不起眼的农村姑娘 谈了二次恋爱 不过都失败告终 十八岁来到...
    受伤的小狐狸阅读 276评论 0 0