zoukankan      html  css  js  c++  java
  • 存储过程总结

    1、存储过程返回数据集的方式:

        通过数据库查询返回数据集;

        通过局部变量返回;

    2、设置output参数的值

        输出参数经常用来从存储过程中检索出结果,如果某个参数在传输到存储过程中时被定义成output,则对该参数的任何修改在退出存储之后任然有效。

       游标可以使用output(输出)参数,但不能使用成输入参数。也就是说,游标可以作为结果返回,但却不能传输到过程中去。当游标被用作参数时,需要限定其为output和varying。varying关键字指出该结果集要用来支持输出参数。这样就提供了将结果集返回到调用过程的能力。 

    3、通过return参数返回状态 

        这是一种从存储过程返回错误码的方法。存储过程总是返回一个状态值,用户也可以使用return语句返回自己的状态。 

    4、在存储过程中进行错误处理 
        如同其它程序一样,在存储过程中进行错误处理是非常重要的。系统变更@@error在执行每一个transact sql语句之后都会得到一个值。对于成功的执行,@@error的值为0,如果出现错误,则   @@error中将包含错误信息。@@error系统变量对存储过程的错误处理是非常重要的。 
        注意:为了防止错误,@@error所能设置的值在sysmessages表的“error”中反映了出来。 

           在存储过程中的错误有两种类型: 
    1、数据库相关的错误 
              这些错误是由数据库的不一致性引起的,系统使用非0的@@error值表示特定的数据库问题。在transact sql执行之后,可以通过@@error获得所出现的错误。如果发现@@error不为0,则必须采取必要的行动,大多数情况下,存储将不再继续进行处理而返回。下面的示例展示了典型的获取数据库错误的方法。该过程将错误代码放置到输出变量中,这样,调用程序就能够访问到。 

    2、业务逻辑错误 
             这些错误是由于违反了业务规则而引起的。要获取这些错误,首先需要定义业务规则,基于这些规则,需要在存储过程中增加必要的错误检测代码。人们经常使用raiserror语句通报这些错误。raiserror提供了返回用户定义错误及将@@error变量设置成用户定义错误号的能力。错误消息可以被动态地建立,或者基于错误号从“sysmessages”表中检索到。一旦出现了错误,错误就会以一种服务器错误消息的方式返回到客户机。下面是raiserror命令的语法: 

  • 相关阅读:
    2017区块链七大趋势,概念热炒之后行业如何发展?
    区块链三大方向:比特币,其他公有链和区块链联盟,以及私有链。
    这条消息被许多人忽视,但对房价可能“一剑封喉”!
    世界主要城市名称中英文对照
    2016全球城市竞争力排行榜
    全球城市群Megalopolis
    gawc全球城市
    2016全球资产配置白皮书(附下载)
    160. Intersection of Two Linked Lists
    save change is not permitted
  • 原文地址:https://www.cnblogs.com/wshsdlau/p/5947340.html
Copyright © 2011-2022 走看看