一、存储过程返回数据集的方式:sql
经过数据库查询返回数据集;数据库
经过局部变量返回;服务器
二、设置output参数的值spa
输出参数常常用来从存储过程当中检索出结果,若是某个参数在传输到存储过程当中时被定义成output,则对该参数的任何修改在退出存储以后任然有效。class
游标可使用output(输出)参数,但不能使用成输入参数。也就是说,游标能够做为结果返回,但却不能传输到过程当中去。当游标被用做参数时,须要限定其为output和varying。varying关键字指出该结果集要用来支持输出参数。这样就提供了将结果集返回到调用过程的能力。 变量
三、经过return参数返回状态 sql语句
这是一种从存储过程返回错误码的方法。存储过程老是返回一个状态值,用户也可使用return语句返回本身的状态。 语法
四、在存储过程当中进行错误处理
如同其它程序同样,在存储过程当中进行错误处理是很是重要的。系统变动@@error在执行每个transact sql语句以后都会获得一个值。对于成功的执行,@@error的值为0,若是出现错误,则 @@error中将包含错误信息。@@error系统变量对存储过程的错误处理是很是重要的。
注意:为了防止错误,@@error所能设置的值在sysmessages表的“error”中反映了出来。 程序
在存储过程当中的错误有两种类型:
一、数据库相关的错误
这些错误是由数据库的不一致性引发的,系统使用非0的@@error值表示特定的数据库问题。在transact sql执行以后,能够经过@@error得到所出现的错误。若是发现@@error不为0,则必须采起必要的行动,大多数状况下,存储将再也不继续进行处理而返回。下面的示例展现了典型的获取数据库错误的方法。该过程将错误代码放置到输出变量中,这样,调用程序就可以访问到。 方法
二、业务逻辑错误 这些错误是因为违反了业务规则而引发的。要获取这些错误,首先须要定义业务规则,基于这些规则,须要在存储过程当中增长必要的错误检测代码。人们常常使用raiserror语句通报这些错误。raiserror提供了返回用户定义错误及将@@error变量设置成用户定义错误号的能力。错误消息能够被动态地创建,或者基于错误号从“sysmessages”表中检索到。一旦出现了错误,错误就会以一种服务器错误消息的方式返回到客户机。下面是raiserror命令的语法: