首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > 其他数据库 >

几时使用SET和SELECT为变量赋值

2013-01-18 
何时使用SET和SELECT为变量赋值我们经常使用SET和SELECT来为变量复制,但是有时候,只能选其一来使用,下面来

何时使用SET和SELECT为变量赋值

        我们经常使用SET和SELECT来为变量复制,但是有时候,只能选其一来使用,下面来看看这些例子,本例中使用AdventureWorks数据库来做演示。

通过查询返回值:

       当你把查询返回的值付给变量时,SET将会接受这个结果(单值)并付给一个标量值。但是SELECT 可以接受查询返回的多个值。

下面来看看单值和多值均使用SET的例子:

       

       



         当使用SET作为多值赋值时,将会报错。因为SET拒绝一个模糊的值(SET不知道应该用哪个值来赋值)。

 

         下面来看看用SELECT来赋值的例子:




         上面演示的例子,平时可以用作检查问题之用。通过SET来跟踪一些错误。

 

对多个变量赋予多个值:

         当需要赋予多个变量值时,使用SELECT 从一个查询中获取数据是首选。因为可以直接赋值,而不用每次都写SET。可以看看下面的例子:




如果需要使用SET,那必须使用多个单独的语句来实现:




通过对比可以明显看出SELECT 在多值赋值的情况下简便很多,并且也高效,因为一次性实现。

 

当赋值失败时会如何?

      当赋值失败时,SET和SELECT 的行为是不一样的。这里的赋值失败可能是没有数据或者数据类型不配等。此时SELECT会返回上一个值(如果上一个值已经赋值成功),而SET会把NULL赋值给变量。不管如何,这种失败的赋值都会产生不可预计的结果,所以需要细心处理。

下面来看看例子:




从结果中可以看出当SET失败时,返回NULL,而SELECT失败时会返回上一个结果。



标准:

很多时候,使用SELECT是一个不错的选择,但是用SELECT来赋值并不符合ANSI标准,所以如果要遵循标准(可能因为要移植代码到别的DBMS),应该使用SET来替代SELECT 。

 

总结:

         其实最好的方法还是通过实践来证明。很多时候的确可以混用,但是有些时候还是建议单独使用:

         使用SET的情景:

  需要直接赋值,且不需要任何查询,比如变量初始化。   故意赋予NULL值。   为了将来的移植而遵循ANSI标准。   赋予非标量值。

 

使用SELECT的情景:

  直接赋予多值变量。  通过查询来赋予变量(单值或多值均可)。检查编码量。为了获取变量如@@ROWCOUNT和@@ERROR的值。


热点排行