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

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

    通过局部变量返回;

2、设置output参数的值

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

 

3、通过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命令的语法: 

 

每一天都要行动,在前进中寻求卓越。