zoukankan      html  css  js  c++  java
  • 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赋值是完全相同的。

  • 相关阅读:
    委托
    队列和栈、泛型
    Java去除字符串中 除数字和逗号以外的符号
    SQL查询重复记录
    使用EasyExcel导出图片及异常处理
    Nacos开机自启
    Redis开机自启
    Nginx开机自启
    Java 向数组中添加元素
    Java:如何打印整个字符串数组?
  • 原文地址:https://www.cnblogs.com/Xujg/p/3338076.html
Copyright © 2011-2022 走看看