SQL Server2008 学习之(十三) :T-SQL语言基础(上)

时间:2022-12-16 16:04:11
这篇和下篇博客主要介绍一些T-SQL的语言基础,主要是梳理一些操作,可以作为参考,在概念不清晰的时候查看。

本文涉及5点:
  • 常量与变量
  • 运算符
  • 表达式
  • 注释
  • 控制语句

1.常量与变量
常量在T-SQL中是不需要声明的。
变量分为全局变量和局部变量。全局变量一般不涉及,平时接触的大多是局部变量,其声明和赋值语句如下。

SQL Server2008 学习之(十三) :T-SQL语言基础(上)

代码如下:
declare @name nvarchar(50)    //定义一个nvarchar类型的数据name
set @name='AA' //用set赋值
select @name='BB' //用select赋值

2.运算符

算术运算符的种类如下图。
    
SQL Server2008 学习之(十三) :T-SQL语言基础(上)    

3.表达式

表达式是一个抽象的概念,不好表达,用一个小例子来说明。
declare @str varchar(50)
select @str='PasswordHash:'+PasswordHash+'PasswordSalt:'+PasswordSalt from Person.Password where BusinessEntityID=1 //此行为一个复杂表达式,通过运算符连接起来
select @str

4.注释

T-SQL中为    /*……*/    与    --

SQL Server2008 学习之(十三) :T-SQL语言基础(上)

5.控制语句

包括if……else、begin……end、case、while

5.1 if……else 与 begin……end 语句示例(输出“不大于10!”)
declare @str int
select @str='10'
if @str<20
begin //begin与end构成语句块,可在if else中嵌套使用
if @str>15
print '大于15小于20!'
else if @str>11
print '大于11小于15!'
else print '不大于10!'
end
else
print '不小于20!'

5.2 case语句示例
select AddressID,City,地址=case City
when 'Bothell' then 'bosaier'
when 'Portland' then 'botelan'
when 'Seattle' then 'xiyatu'
else 'others'
end
from Person.Address order by AddressID ASC
Person.Address原始数据如下左图,输出结果如右下图:

SQL Server2008 学习之(十三) :T-SQL语言基础(上)
        
5.3 while语句
declare @i int,@num int
set @i='1'
set @num='1'
while @i<10
begin
set @num=@num*@i
set @i=@i+1
print @num //每次循环都输出
end

结果如下图

SQL Server2008 学习之(十三) :T-SQL语言基础(上)

5.4 wait……for延迟语句
wait……for语法格式如下。其作用是延迟一段时间后再执行语句

SQL Server2008 学习之(十三) :T-SQL语言基础(上)

wait for delay '00:00:05'    //延迟一段时间后执行
print 'reach 5 sec'
wait for time '21:01:20' //到达系统时间后执行
print 'reach 21:01:20'
5.5 GOTO语句
GOTO语句可以在程序执行到某个特定时刻时,执行标签上的具体操作。
declare @X int
set @X=1
loving:
print @X
set @X=@X+1
while @X<=3 goto loving
输出结果:1 2 3
5.6 try……catch语句
try……catch语句用以检查错误
begin try
declare @num int
set @num=1/0
select @num
end try
begin catch
select ERROR_LINE() as '错误行数',ERROR_MESSAGE() as '错误消息'
end catch

输出错误信息
SQL Server2008 学习之(十三) :T-SQL语言基础(上)