• SQL Server变量赋值的方法


    SQL Server变量赋值我们经常会遇到,下面就为您介绍SQL Server变量赋值的两种方法,希望可以对您学习SQL Server变量赋值有所帮助。

    SQL Server中对已经定义的SQL Server变量赋值的方式用两种,分别是SET和SELECT。

    对于这两种SQL Server变量赋值方式的区别,SQL Server 联机丛书中已经有详细的说明,但很多时候我们并没有注意,其实这两种方式还是有很多差别的。

    SQL Server推荐使用SET而不是SELECT对变量进行赋值。当表达式返回一个值并对一个变量进行赋值时,推荐使用SET方法。

    下面以具体示例来说明问题: 
    create table chinadba1( 
    userid int , 
    addr varchar(128)  

    go 
    insert into chinadba1(userid,addr) values(1,'addr1') 
    insert into chinadba1(userid,addr) values(2,'addr2') 
    insert into chinadba1(userid,addr) values(3,'addr3') 
    go

    表达式返回多个值时,使用SET赋值  
    declare @addr varchar(128) 
    set @addr = (select addr from chinadba1) 
    /* 
    --出错信息为 
    服务器: 消息 512,级别 16,状态 1,行 2 
    子查询返回的值多于一个。当子查询跟随在 =、!=、<、<=、>、>= 之后,或子查询用作表达式时,这种情况是不允许的。 
    */ 
    go 
    表达式返回多个值时,使用SELECT赋值 declare @addr varchar(128) 
    select @addr = addr from chinadba1 
    print @addr --结果集中最后一个 addr 列的值 
    --结果: addr3  
    go 
    表达式未返回值时,使用SET赋值 declare @addr varchar(128) 
    set @addr = '初始值' 
    set @addr = (select addr from chinadba1 where userid = 4 ) 
    print @addr --null值  
    go 
    表达式未返回值时,使用SELECT赋值 declare @addr varchar(128) 
    set @addr = '初始值' 
    select @addr = addr from chinadba1 where userid = 4 
    print @addr --保持原值 
    go 
    需要注意的是,SELECT 也可以将标量子查询的值赋给变量,如果标量子查询不返回值,则变量被置为 null 值。 
    此时与使用SET赋值是完全相同的。

  • 相关阅读:
    ini 文件
    基元类型、引用 类型与值类型
    C#的 is 和 as 类型转换
    MVC 项目中为什么会有两个web.config
    Linux下安装SVN服务端小白教程
    测试博文中添加可执行JS代码
    坑爹坑娘坑祖宗的87端口(记一次tomcat故障排查)
    fsfds
    高斯混合模型Gaussian Mixture Model (GMM)
    ggplot2绘制概率密度图
  • 原文地址:https://www.cnblogs.com/Xujg/p/3338076.html
Copyright © 2020-2023  润新知