SQL server数据库declare和set用法技巧小结

 更新时间:2023年08月11日 10:00:58   作者:帝火流冰  
这篇文章主要给大家介绍了关于SQL server数据库declare和set用法技巧的相关资料,在SQL Server中,DECLARE用于声明变量和存储过程中的参数,文中通过实例代码介绍的非常详细,需要的朋友可以参考下

最近遇到一段不怎么看得懂的SQL语句,经过查阅资料,整理出来的有关数据拼接、数据库变量的一些内容如下:

如根据下述学生表,若要求得到年龄最大的学生信息:

学号15001150021500316004
姓名张三李四王丽薇姿
性别
年龄20201922

不使用变量的情况下,可用嵌套查询实现:

Select * from 学生表 where 年龄=(select max(年龄) from 学生表)

运用变量解决上述问题:

        Declare @bianliang int;
        Set @bianliang=(select max(年龄) from 学生表);
        Select * from 学生表 where 年龄=@bianliang

面对实际工作中海量纷繁复杂的数据,使用嵌套或连接查询时很容易出现各种语句错误,此时可以通过引入变量的方式将数据之间的逻辑关系简单化、清晰化。

SQL Server中变量的使用主要涉及三方面的内容,即定义变量,为变量赋值以及结果的显示。

一、定义/声明变量

变量分为全局变量和局部变量,全局变量一般是系统内置的,用户使用时一般无法自行定义,实际工作中也只需要使用局部变量。定义变量的语句如下(定义多个变量时需用逗号隔开):

Declare @变量名1  数值类型,@变量名2  数值类型,@变量名3  数值类型,……

如:declare @i1  int,@i2  nvarchar(10),@i3  money,……

二、为变量赋值

可以使用set或select命令为变量赋值,可以直接将某个具体的值赋给变量,也可以将一个需要经过运算产生的查询结果赋给变量。

1.直接赋值

如声明变量:declare @bl1 int,@bl2  nvarchar(10),@bl3  money;

分别使用set和select分别为上述3个变量赋值:

set @bl1=100;  set @bl2='hello' ;  set @bl3=3.1415926  ;          

Select @bl1=100, @bl2='hello',@bl3=3.1415926 ;

2.为变量赋一个需要运算产生结果的值

如声明变量:Declare @bl int;

以前文的学生表为例,分别使用set和select将学生表中学生年龄的最大值赋给变量@bl:

Set @bl=(select max(年龄) from学生表);

Select @bl=max(年龄) from 学生表;

3.set与select为变量赋值时的区别

直接赋值时set与select并无区别,只有所赋的值是一个查询结果时二者才有不同,当查询结果唯一时(如最大最小值),set和select都可以完成赋值,但是查询结果不止一个时使用set会提示错误。

如查询前文学生表中学生年龄:

Declare @bl int;
Set @bl=(select 年龄 from 学生表);

则变量@bl的赋值无法完成,因为学生表中年龄不止一条记录。而此时select命令仍可以产生结果。

Declare @bl int;
Select @bl=年龄 from 学生表;

此时变量@i的值为22,即表中最后一行年龄数据。这是因为select对变量的赋值方式是遍历数据中的全部记录,然后将最后一条记录赋给变量。

4.使用select命令为变量赋值的应用

了解了select为变量赋值时遍历全部数据的特性,用户可以运用变量将表中的一列记录变成一行值显示,仍以前文提到的学生表为例:

Declare @i varchar(100)
Set @i=''
Select @i=@i+姓名 from学生表

此时变量@i的值为“张三李四王丽薇姿”。

这种方法在实际工作中可以结合存储过程运用,提高SQL语句执行效率。需要注意的是,若上例的学生表中“姓名”列有null值,则变量@i的值也是null,这是因为null与任何值进行运算结果都是null,此时需要通过isnull函数对null值进行调整。

三、显示结果

变量的结果有两种显示方式,即文本显示(print)和表格显示(select)两种.

总结

相关文章

  • 关于SQL中CTE(公用表表达式)(Common Table Expression)的总结

    关于SQL中CTE(公用表表达式)(Common Table Expression)的总结

    WITH AS短语,也叫做子查询部分(subquery factoring),可以让你做很多事情,定义一个SQL片断,该SQL片断会被整个SQL语句所用到
    2012-08-08
  • 当恢复sqlserver bak文件时,原始的用户无法删除的解决方法

    当恢复sqlserver bak文件时,原始的用户无法删除的解决方法

    当你从现有的bak文件,恢复数据库时,如果数据库本身带有一个用户:比如用户叫:DemoUser.
    2010-06-06
  • 删除重复记录,并且剩下一条

    删除重复记录,并且剩下一条

    所谓的重复记录就是某列数据有重复的,但是在实际的过程中,有可能您的需求是一列有重复,也可能两列有重复..根据实际情况,所得到的重复记录是有所不同的
    2009-04-04
  • sql server2008调试存储过程的完整步骤

    sql server2008调试存储过程的完整步骤

    这篇文章主要给大家分享介绍了关于sql server2008调试存储过程的完整步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • sql中的regexp与like区别实现

    sql中的regexp与like区别实现

    本文详细介绍了正则表达式REGEXP和LIKE语句的用途,使用它们进行模式匹配,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-09-09
  • ODBC连接数据库以SQLserver为例图文详解

    ODBC连接数据库以SQLserver为例图文详解

    开放数据库互连(ODBC)是微软提出的数据库访问接口标准,开放数据库互连定义了访问数据库的API一个规范,这些API独立于不同厂商的DBMS,也独立于具体的编程语言,下面这篇文章主要给大家介绍了关于ODBC连接数据库以SQLserver为例的相关资料,需要的朋友可以参考下
    2023-05-05
  • SQL Server误区30日谈 第26天 SQL Server中存在真正的“事务嵌套”

    SQL Server误区30日谈 第26天 SQL Server中存在真正的“事

    嵌套事务可不会像其语法表现的那样看起来允许事务嵌套。我真不知道为什么有人会这样写代码,我唯一能够想到的就是某个哥们对SQL Server社区嗤之以鼻然后写了这样的代码说:“玩玩你们”
    2013-01-01
  • SQL多表联合查询时如何采用字段模糊匹配

    SQL多表联合查询时如何采用字段模糊匹配

    这篇文章主要介绍了SQL多表联合查询时如何采用字段模糊匹配,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • Oracle中sql语句如何执行日志查询

    Oracle中sql语句如何执行日志查询

    这篇文章主要介绍了Oracle中sql语句如何执行日志查询,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • mybatis collection 多条件查询的实现方法

    mybatis collection 多条件查询的实现方法

    这篇文章主要介绍了mybatis collection 多条件查询的实现方法的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
    2017-10-10

最新评论