sql:select赋值和set赋值的区别

时间:2022-07-19 10:46:15

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赋值会返回之前的值。