这篇和下篇博客主要介绍一些T-SQL的语言基础,主要是梳理一些操作,可以作为参考,在概念不清晰的时候查看。
本文涉及5点:
- 常量与变量
- 运算符
- 表达式
- 注释
- 控制语句
1.常量与变量
常量在T-SQL中是不需要声明的。
变量分为全局变量和局部变量。全局变量一般不涉及,平时接触的大多是局部变量,其声明和赋值语句如下。
代码如下:
declare @name nvarchar(50) //定义一个nvarchar类型的数据name
set @name='AA' //用set赋值
select @name='BB' //用select赋值
2.运算符
算术运算符的种类如下图。
3.表达式
表达式是一个抽象的概念,不好表达,用一个小例子来说明。
declare @str varchar(50)
select @str='PasswordHash:'+PasswordHash+'PasswordSalt:'+PasswordSalt from Person.Password where BusinessEntityID=1 //此行为一个复杂表达式,通过运算符连接起来
select @str
4.注释
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原始数据如下左图,输出结果如右下图:
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
结果如下图
5.4 wait……for延迟语句
wait……for语法格式如下。其作用是延迟一段时间后再执行语句
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
输出错误信息