一、T-SQL 中变量分为两种:局部变量和全局变量
1、局部变量:用户可以自定义的变量,作用范围仅在程序内部有效。
2、定义方式:DECLARE @变量名称 变量类型 [,@变量名称 变量类型 ...]
局部变量必须以@开头,必须先用DECLARE命令声明,之后才可以使用。其中变量类型是SQL Server2005所支持的全部数据类型。
示例:
DECLARE @name nvarchar(30),@age int
在局部变量没有被赋值之前,它的值是NULL。如果要在程序体中引用它,就必须先给它赋值。
4、变量的赋值语法:
SELECT @局部变量 = 变量值
SET @局部变量 = 变量值
变量的赋值使用SELECT 或SET 命令来设置变量的值。
变量的输出一般使用SELECT或PRINT语句来显示在屏幕上
SELECT @局部变量或 PRINT @局部变量
示例
1)声明一个计数器变量,并在循环结构中加1后输出。
DECLARE @counter int --声明变量
SELECT @counter =100 --为变量赋值
WHILE @counter <100 --循环
BEGIN
SELECT @counter = @counter +1 --循环并变量加1
PRINT @counter --输出变量
END
2) 查询图书编号为1001的图书名称和价格,并将其分别赋值给变量bookname和price。
DECLARE @bookname nvarchar(50),@price float(2) --声明变量及类型
SELECT @bookname = bookname,@price = price FROM book WHERE bookid = 1001
PRINT @bookname AS name,@price AS price
二、全局变量
全局变量是SQL Server系统内部使用的变量,作用范围是任何程序。
全局变量不是也不能由用户程序定义,是服务器级定义的,用户只能引用系统中已经定义的全局变量。
应用全局变量时必须以@@开头。
局部变量名称不能与全局变量名称相同。
常用全局变量机器作用
变量名称 作用
@@rowcount 前一条sql语句处理的行数
@@error 前一条sql语句报错的错误号
@@servername 本地SQL Server的名称
@@nestlevel 存储过程/触发器中嵌套层
@@fetch_status 有表中上条fetch语句的状态
三、高级查询
----写入新表
if exits (select * from sysobjects where name='新表名字' )
drop table 新表名字
convert(varchar(5),labExam)
如果单对那一列进行判断,直接在列名后用case end块处理
四、合并表中的数据3中方式
1.Union联合
2.子查询
3.连接
1、局部变量:用户可以自定义的变量,作用范围仅在程序内部有效。
2、定义方式:DECLARE @变量名称 变量类型 [,@变量名称 变量类型 ...]
局部变量必须以@开头,必须先用DECLARE命令声明,之后才可以使用。其中变量类型是SQL Server2005所支持的全部数据类型。
示例:
DECLARE @name nvarchar(30),@age int
在局部变量没有被赋值之前,它的值是NULL。如果要在程序体中引用它,就必须先给它赋值。
4、变量的赋值语法:
SELECT @局部变量 = 变量值
SET @局部变量 = 变量值
变量的赋值使用SELECT 或SET 命令来设置变量的值。
变量的输出一般使用SELECT或PRINT语句来显示在屏幕上
SELECT @局部变量或 PRINT @局部变量
示例
1)声明一个计数器变量,并在循环结构中加1后输出。
DECLARE @counter int --声明变量
SELECT @counter =100 --为变量赋值
WHILE @counter <100 --循环
BEGIN
SELECT @counter = @counter +1 --循环并变量加1
PRINT @counter --输出变量
END
2) 查询图书编号为1001的图书名称和价格,并将其分别赋值给变量bookname和price。
DECLARE @bookname nvarchar(50),@price float(2) --声明变量及类型
SELECT @bookname = bookname,@price = price FROM book WHERE bookid = 1001
PRINT @bookname AS name,@price AS price
二、全局变量
全局变量是SQL Server系统内部使用的变量,作用范围是任何程序。
全局变量不是也不能由用户程序定义,是服务器级定义的,用户只能引用系统中已经定义的全局变量。
应用全局变量时必须以@@开头。
局部变量名称不能与全局变量名称相同。
常用全局变量机器作用
变量名称 作用
@@rowcount 前一条sql语句处理的行数
@@error 前一条sql语句报错的错误号
@@servername 本地SQL Server的名称
@@nestlevel 存储过程/触发器中嵌套层
@@fetch_status 有表中上条fetch语句的状态
三、高级查询
----写入新表
if exits (select * from sysobjects where name='新表名字' )
drop table 新表名字
convert(varchar(5),labExam)
如果单对那一列进行判断,直接在列名后用case end块处理
四、合并表中的数据3中方式
1.Union联合
2.子查询
3.连接