当前位置: 澳门新濠3559 > 数据库 > 正文

' 附近有语法错误

时间:2019-11-22 23:13来源:数据库
declare @name varchar 下表列出SET 与 SELECT 的区别   exec sp_executesql N'select @value=姓名 from people where人员编号=''0001''',N'@value varchar output',@name output   SELECT SET 同时对多个变量同时赋值时 支持 不

declare @name varchar

下表列出 SET 与 SELECT 的区别

 

exec sp_executesql N'select @value=姓名 from people where 人员编号=''0001''',N'@value varchar output',@name output

  SELECT SET
同时对多个变量同时赋值时 支持 不支持
表达式返回多个值时 将返回的最后一个值赋给变量 出错
表达式未返回值时 变量保持原值 变量被赋null值

' 附近有语法错误。 

select @name

(1).同时对多个变量同时赋值时

create table #Data(name varchar(100),row varchar(100),reserved varchar(100),data varchar(100),index_size varchar(100),unused varchar(100))

declare @a varchar(128), @b varchar(128) SET @a='ABC',@b='EFG' GO --报错:消息 102,级别 15,状态 1,第 3 行 ',' 附近有语法错误。

declare @name varchar(100)
declare cur cursor for
select name from sysobjects where xtype='u' order by name
open cur
fetch next from cur into @name
while @@fetch_status=0
begin
insert into #data
exec sp_spaceused @name
print @name

declare @a varchar(128), @b varchar(128) SELECT @a='ABC',@b='EFG' GO --正确运行

fetch next from cur into @name
end
close cur
deallocate cur

(2).表达式返回多个值时

create table #DataNew(name varchar(100),row int,reserved int,data int,index_size int,unused int)

在说明这一项前我们先创建一个要用到的表,并对其赋值,代码如下:

insert into #dataNew
澳门新濠3559,select name,convert(int,row) as row,convert(int,replace(reserved,'KB','')) as reserved,convert(int,replace(data,'KB','')) as data,
convert(int,replace(index_size,'KB','')) as index_size,convert(int,replace(unused,'KB','')) as unused from #data

 

select name,CAST(data AS FLOAT)/(SUM(data) OVER()) from #dataNew
ORDER by data desc

澳门新濠3559 1澳门新濠3559 2赋值测试表--fuzhiTEST

 

澳门新濠3559 3

create table fuzhiTEST(
id int ,
name varchar(128)
)
go
insert into fuzhiTEST(id,name) values(1,'name1')
insert into fuzhiTEST(id,name) values(2,'name2')
insert into fuzhiTEST(id,name) values(3,'name3')
go

澳门新濠3559 4

 

declare @name varchar(128) set @name = (select name from fuzhiTEST) GO  --报错:消息 512,级别 16,状态 1,第 2 行        

子查询返回的值不止一个。当子查询跟随在 =、!=、<、<=、>、>= 之后,或子查询用作表达式时,这种情况是不允许的。

declare @name varchar(128) select @name =name from fuzhiTEST print @name GO  --正确运行:显示 name3

(3).表达式未返回值时

declare @name varchar(128) set @name = 'SET初始值' set @name = (select name from fuzhiTEST where id = 4 ) print @name GO   --正确运行:显示NULL

declare @name varchar(128) set @name = 'SELECT初始值' select @name = name from fuzhiTEST where id = 4 print @name --正确运行:显示 SELECT初始值

注意:SELECT 也可以将标量子查询的值赋给变量,如果标量子查询不返回值,则变量被置为 null 值(此时与使用 SET 赋值是完全相同的)。 对标量子查询的概念大家可能觉得陌生,下面举个例子说明下(对比上面绿色部分):

declare @name varchar(128) set @name = 'SELECT初始值' select @name =(select name from fuzhiTEST where id = 4 ) print @name --正确运行:显示NULL

来源

 

 

编辑:数据库 本文来源:' 附近有语法错误

关键词: