zoukankan      html  css  js  c++  java
  • !!!SQL中select与set的区别

    复制代码
    下表列出 SET 与 SELECT 的区别
      SELECT SET
    同时对多个变量同时赋值时 支持 不支持
    表达式返回多个值时 将返回的最后一个值赋给变量 出错
    表达式未返回值时 变量保持原值 变量被赋null值
    (1).同时对多个变量同时赋值时
    
    declare @a varchar(128), @b varchar(128)
    SET @a='ABC',@b='EFG'
    GO --报错:消息 102,级别 15,状态 1,第 3 行 ',' 附近有语法错误。
    
     
    
    declare @a varchar(128), @b varchar(128)
    SELECT @a='ABC',@b='EFG'
    GO --正确运行
    
     
    
    (2).表达式返回多个值时
    
    在说明这一项前我们先创建一个要用到的表,并对其赋值,代码如下:
    
     
    
    
    复制代码
    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
    复制代码
     
    
    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初始值
    GO
    
    注意:SELECT 也可以将标量子查询的值赋给变量,如果标量子查询不返回值,则变量被置为 null 值(此时与使用 SET 赋值是完全相同的)。
    对标量子查询的概念大家可能觉得陌生,下面举个例子说明下(对比上面绿色部分):
    
    declare @name varchar(128)
    set @name = 'SELECT初始值'
    select @name =(select name from fuzhiTEST where id = 4 )
    print @name --正确运行:显示NULL
    GO
    
  • 相关阅读:
    『Delphi』字符串操作——返回子串出现的位置
    2007:远见、劲取、专注
    『转载』个人博客吸引风投关注成可盈利业务
    [和管子对话] 1 200745/对面向对象的你言我语
    『Delphi』File not found的解决办法
    Ruby学习1字符串
    聚集表(clustered table)data page中的数据行可以无序
    通过DBCC PAGE查看页信息验证聚集索引和非聚集索引节点信息
    查看SQL Server Resource Database以及修改系统表
    SQL Server的还原(2)——STOPAT
  • 原文地址:https://www.cnblogs.com/ROCKyou/p/4759869.html
Copyright © 2011-2022 走看看