数据库变量相关知识介绍

    作者:数据库技术分享社区更新于: 2022-01-17 15:14:11

    数据库知识:SQLServer变量相关知识介绍

    数据库是一个 单位或是一个应用领域的通用数据处理系统,它存储的是属于企业和事业部门、 团体和个人的有关数据的 集合。数据库中的数据是从全局观点出发建立的,按一定的 数据模型进行组织、描述和存储。其结构基于数据间的自然联系,从而可提供一切必要的存取 路径,且数据不再针对某一应用,而是面向全组织,具有整体的结构化特征。

     1、概述

    SQLServer变量对应内存中的一个存储空间。它和常量不同,变量的值可以在执行过程中改变。

    数据库变量相关知识介绍_数据库_MySQL_数据结构_课课家

    2、分类

    SQLServer变量根据作用范围不同主要分为局部变量和全局变量。

    2.1.局部变量

    局部变量是用户在程序中定义的变量,它仅在定义的程序范围内有效。局部变量可以用来保存从表中读取的数据,也可以作为临时变量保存计算的中间结果。

    注意:局部变量名称的第一个字符必须为一个@。

    示例:

    1. -- 定义两个局部变量 
    2. DECLARE @m int,@n int
    3. -- 赋值 
    4. SET @m=9; 
    5. SET @n=1; 
    6. -- 查询 
    7. SELECT @m+@n; 

    2.2 全局变量

    全局变量通常以@@开头。这些变量一般都是SQL Server中的系统函数,它们的语法遵循函数的规则。用户可以在程序中使用这些函数测试系统特性和SQL命令的执行情况。常用的全局变量如下:

    1. @@ERROR -- 最后一个SQL错误的错误号 
    2. @@IDENTITY -- 最后一次插入的标识值 
    3. @@LANGUAGE -- 当前使用的语言的名称 
    4. @@MAX_CONNECTIONS -- 可以创建的同时连接的最大数目 
    5. @@ROWCOUNT -- 受上一个SQL语句影响的行数 
    6. @@SERVERNAME -- 本地服务器的信息 
    7. @@TRANSCOUNT -- 当前连接打开的事物数 
    8. @@VERSION -- 查看SQL Server的版本信息 

    3.声明变量

    3.1、简单声明

    变量只有在声明后才能使用,可以使用DECLARE语句来声明变量。在声明变量时可以指定变量的数据类型和长度。

    1. DECLARE @name nvarchar(30); 

    3.2 声明多个变量

    声明多个局部变量,需要在定义的局部变量后使跟上一个逗号,然后指定下一个局部变量名称和数据类型。

    1. DECLARE @Name nvarchar(30), @Age int

    3.3 变量作用域

    在使用变量时,需要注意变量的作用域。变量具有局部作用域,只在定义它们的批处理或过程中可见。作用域范围从声明变量的地方开始到声明变量的批处理或存储过程的结尾。

    1. USE DB; 
    2. GO 
    3. DECLARE @Age int
    4. SET @Age = 30; 
    5. GO -- 结束符 
    6. select @Age -- 报错 

    4.变量赋值

    在声明变量后,变量值被默认设置为NULL。可以使用SET或SELECT语句。SET是为变量赋值的首选方法。

    变量也可以通过选择列表中当前所引用的值赋值。如果在选择列表中引用变量,则它应当被赋以标量值或者SELECT语句应仅返回一行。

    示例:

    1. DECLARE @Age int
    2. -- SELECT语句赋值 
    3. SELECT @Age = age from t_user ORDER BY age desc;-- 返回最后一行的值 
    4. select @Age; 
      这种数据集合具有如下特点:尽可能不重复,以最优方式为某个特定组织的多种应用服务,其数据结构独立于使用它的应用程序,对数据的增、删、改、查由统一软件进行管理和控制。从发展的历史看,数据库是数据管理的高级阶段,它是由文件管理系统发展起来的。

课课家教育

未登录