1)Set写法
declare @i integer
set @i=(select count(*) from test)
select @i
Select写法
declare @i integer
select @i=(select count(*) from test)
select @i
或
declare @i integer
select @i =count(*) from test
select @i
从中可以看出的区别:
set语句可以被Select代替,但反过来不一定可以。set赋值必须使用子查询,用括号括起来;select可以直接赋值。
另外:
如果查询结果有多个,set会出错;而selecte会使用最后一个结果来赋值。
2)
假定数据库中id=10的数据不存在,那么:
Select写法
declare @i integer
set @i=5
select @i =id from test where id=10
select @i
返回 5
Set写法
declare @i integer
set @i=5
select @i =id from test where id=10
select @i
返回 null
从这点可以看出,如果查询结果为空,那么set赋值会返回NULL,而select赋值会返回之前的值。