长度与分析用
|
| |
datalength(Char_expr)
|
返回字符串包含字符数
,
但不包含后面的空格
|
|
substring(expression,start,length)
|
不多说了
,
取子串
|
|
right(char_expr,int_expr)
|
返回字符串右边
int_expr
个字符
|
|
字符操作类
|
| |
upper(char_expr)
|
转为大写
|
|
lower(char_expr)
|
转为小写
|
|
space(int_expr)
|
生成
int_expr
个空格
|
|
replicate(char_expr,int_expr)
|
复制字符串
int_expr
次
|
|
reverse(char_expr)
|
反转字符串
|
|
stuff(char_expr1,start,length,char_expr2)
|
将字符串
char_expr1
中的从
start
开始的
length
个字符用
char_expr2
代替
|
|
ltrim(char_expr) rtrim(char_expr)
|
取掉空格
|
|
ascii(char) char(ascii)
|
两函数对应
,
取
ascii
码
,
根据
ascii
吗取字符
|
|
字符串查找
|
| |
charindex(char_expr,expression)
|
返回
char_expr
的起始位置
|
|
patindex("%pattern%",expression)
|
返回指定模式的起始位置
,
否则为
0
|
|
数学函数
|
| |
abs(numeric_expr)
|
求绝对值
|
|
ceiling(numeric_expr)
|
取大于等于指定值的最小整数
|
|
exp(float_expr)
|
取指数
|
|
floor(numeric_expr)
|
小于等于指定值得最大整数
|
|
pi()
|
3.1415926.........
|
|
power(numeric_expr,power)
|
返回
power
次方
|
|
rand([int_expr])
|
随机数产生器
|
|
round(numeric_expr,int_expr)
|
按
int_expr
规定的精度四舍五入
|
|
sign(int_expr)
|
根据正数
,0,
负数
,,
返回
+1,0,-1
|
|
sqrt(float_expr)
|
平方根
|
|
日期函数
| ||
getdate()
|
返回日期
| |
datename(datepart,date_expr)
|
返回名称如
June
| |
datepart(datepart,date_expr)
|
取日期一部份
| |
datediff(datepart,date_expr1.dateexpr2)
|
日期差
| |
dateadd(datepart,number,date_expr)
|
返回日期加上
number
| |
convert()
|
日期转换
|
上述函数中
datepart
的
写法
取值和意义
yy 1753-9999
年份
qq 1-4
刻
mm 1-12
月
dy 1-366
日
dd 1-31
日
wk 1-54
周
dw 1-7
周几
hh 0-23
小时
mi 0-59
分钟
ss 0-59
秒
ms 0-999
毫秒
SQL
流程控制命令
(1)
Transact-SQL
语言使用的流程控制命令与常见的程序设计语言类似主要有以下几种控制命令。
1 IF…ELSE
其语法如下:
IF < 条件表达式 >
< 命令行或程序块 >
[ELSE [ 条件表达式 ]
< 命令行或程序块 >]
其中 < 条件表达式 > 可以是各种表达式的组合,但表达式的值必须是逻辑值 “ 真 ” 或 “ 假 ” 。 ELSE 子句是可选的,最简单的 IF 语句没有 ELSE 子句部分。 IF…ELSE 用来判断当某一条件成立时执行某段程序,条件不成立时执行另一段程序。如果不使用程序块, IF 或 ELSE 只能执行一条命令。 IF…ELSE 可以进行嵌套。
其语法如下:
IF < 条件表达式 >
< 命令行或程序块 >
[ELSE [ 条件表达式 ]
< 命令行或程序块 >]
其中 < 条件表达式 > 可以是各种表达式的组合,但表达式的值必须是逻辑值 “ 真 ” 或 “ 假 ” 。 ELSE 子句是可选的,最简单的 IF 语句没有 ELSE 子句部分。 IF…ELSE 用来判断当某一条件成立时执行某段程序,条件不成立时执行另一段程序。如果不使用程序块, IF 或 ELSE 只能执行一条命令。 IF…ELSE 可以进行嵌套。
例
declare@x int,@y int,@z int
select @x=1,@y=2, @z=3
if@x>@y
print’x>y’ -- 打印字符串 ’x>y’
else if@y>@z
print’y>z’
else print’z>y’
运行结果如下
z>y
注意:在 Transact-SQL 中最多可嵌套 32 级。
select @x=1,@y=2, @z=3
if@x>@y
print’x>y’ -- 打印字符串 ’x>y’
else if@y>@z
print’y>z’
else print’z>y’
运行结果如下
z>y
注意:在 Transact-SQL 中最多可嵌套 32 级。
2 BEGIN…END
其语法如下:
BEGIN
< 命令行或程序块 >
END
BEGIN…END 用来设定一个程序块,将在 BEGIN…END 内的所有程序视为一个单元执行 BEGIN…END 经常在条件语句,如 IF…ELSE 中使用。在 BEGIN…END 中可嵌套另外的 BEGIN…END 来定义另一程序块。
其语法如下:
BEGIN
< 命令行或程序块 >
END
BEGIN…END 用来设定一个程序块,将在 BEGIN…END 内的所有程序视为一个单元执行 BEGIN…END 经常在条件语句,如 IF…ELSE 中使用。在 BEGIN…END 中可嵌套另外的 BEGIN…END 来定义另一程序块。
3 CASE
CASE 命令有两种语句格式 :
CASE < 运算式 >
WHEN < 运算式 >THEN< 运算式 >
…
WHEN< 运算式 >THEN< 运算式 >
[ELSE< 运算式 >]
END
CASE 命令有两种语句格式 :
CASE < 运算式 >
WHEN < 运算式 >THEN< 运算式 >
…
WHEN< 运算式 >THEN< 运算式 >
[ELSE< 运算式 >]
END
CASE
WHEN < 条件表达式 > THEN < 运算式 >
WHEN < 条件表达式 > THEN < 运算式 >
[ELSE < 运算式 >]
END
CASE 命令可以嵌套到 SQL 命令中。
例 4-10 :调整员工工资,工作级别为 “1” 的上调 8% ,工作级别为 “2” 的上调 7% ,工作级别为 “3” 的上调 6% ,其它上调 5% 。
use pangu
update employee
set e_wage =
case
when job_level = ’1’ then e_wage*1.08
when job_level = ’2’ then e_wage*1.07
when job_level = ’3’ then e_wage*1.06
else e_wage*1.05
end
注意 : 执行 CASE 子句时,只运行第一个匹配的子名。
WHEN < 条件表达式 > THEN < 运算式 >
WHEN < 条件表达式 > THEN < 运算式 >
[ELSE < 运算式 >]
END
CASE 命令可以嵌套到 SQL 命令中。
例 4-10 :调整员工工资,工作级别为 “1” 的上调 8% ,工作级别为 “2” 的上调 7% ,工作级别为 “3” 的上调 6% ,其它上调 5% 。
use pangu
update employee
set e_wage =
case
when job_level = ’1’ then e_wage*1.08
when job_level = ’2’ then e_wage*1.07
when job_level = ’3’ then e_wage*1.06
else e_wage*1.05
end
注意 : 执行 CASE 子句时,只运行第一个匹配的子名。
4 WHILE…CONTINUE…BREAK
其语法如下 :
WHILE < 条件表达式 >
BEGIN
< 命令行或程序块 >
[BREAK]
[CONTINUE]
[ 命令行或程序块 ]
END
WHILE 命令在设定的条件成立时会重复执行命令行或程序块。 CONTINUE 命令可以让程序跳过 CONTINUE 命令之后的语句,回到 WHILE 循环的第一行命令。 BREAK 命令则让程序完全跳出循环,结束 WHILE 命令的执行。 WHILE 语句也可以嵌套。
例 4-11:declare @x int, @y int, @c int
select @x = 1, @y=1
while @x < 3
begin
print @x -- 打印变量 x 的值
while @y < 3
begin
select @c = 100*@ x+ @y
print @c -- 打印变量 c 的值
select @y = @y + 1
end
select @x = @x + 1
select @y = 1
end
运行结果如下
1
101
102
2
201
202
其语法如下 :
WHILE < 条件表达式 >
BEGIN
< 命令行或程序块 >
[BREAK]
[CONTINUE]
[ 命令行或程序块 ]
END
WHILE 命令在设定的条件成立时会重复执行命令行或程序块。 CONTINUE 命令可以让程序跳过 CONTINUE 命令之后的语句,回到 WHILE 循环的第一行命令。 BREAK 命令则让程序完全跳出循环,结束 WHILE 命令的执行。 WHILE 语句也可以嵌套。
例 4-11:declare @x int, @y int, @c int
select @x = 1, @y=1
while @x < 3
begin
print @x -- 打印变量 x 的值
while @y < 3
begin
select @c = 100*@ x+ @y
print @c -- 打印变量 c 的值
select @y = @y + 1
end
select @x = @x + 1
select @y = 1
end
运行结果如下
1
101
102
2
201
202
5 WAITFOR
其语法如下 :
WAITFOR {DELAY <‘ 时间 ’> | TIME <‘ 时间 ’>
| ERROREXIT | PROCESSEXIT | MIRROREXIT}
WAITFOR 命令用来暂时停止程序执行,直到所设定的等待时间已过或所设定的时间已到才继续往下执行。其中 ‘ 时间 ’ 必须为 DATETIME 类型的数据,如: ‘11:15:27’ ,
但不能包括日期各关键字含义如下:
其语法如下 :
WAITFOR {DELAY <‘ 时间 ’> | TIME <‘ 时间 ’>
| ERROREXIT | PROCESSEXIT | MIRROREXIT}
WAITFOR 命令用来暂时停止程序执行,直到所设定的等待时间已过或所设定的时间已到才继续往下执行。其中 ‘ 时间 ’ 必须为 DATETIME 类型的数据,如: ‘11:15:27’ ,
但不能包括日期各关键字含义如下:
DELAY 用来设定等待的时间最多可达 24 小时;
TIME 用来设定等待结束的时间点;
ERROREXIT 直到处理非正常中断;
PROCESSEXIT 直到处理正常或非正常中断;
MIRROREXIT 直到镜像设备失败。
例 4-12 等待 1 小时 2 分零 3 秒后才执行 SELECT 语句
waitfor delay ’01:02:03’
select * from employee
例
4-13
:等到晚上
11
点零
8
分后才执行
SELECT
语句
waitfor time ’23:08:00’
select * from employee
waitfor time ’23:08:00’
select * from employee
6 GOTO
语法如下:
GOTO 标识符
GOTO 命令用来改变程序执行的流程,使程序跳到标有标识符的指定的程序行再继续往下执行。作为跳转目标的标识符可为数字与字符的组合,但必须以 “ : ” 结尾,如 ‘12 : ’ 或 ‘a_1 : ’ 。在 GOTO 命令行,标识符后不必跟 “ : ” 。
例 4-14 分行打印字符 ‘1’ 、 ‘2’ 、 ‘3’ 、 ‘4’ 、 ‘5’
declare @x int
select @x = 1
label_1
print @x
select @x = @x + 1
while @x < 6
goto label_1
GOTO 标识符
GOTO 命令用来改变程序执行的流程,使程序跳到标有标识符的指定的程序行再继续往下执行。作为跳转目标的标识符可为数字与字符的组合,但必须以 “ : ” 结尾,如 ‘12 : ’ 或 ‘a_1 : ’ 。在 GOTO 命令行,标识符后不必跟 “ : ” 。
例 4-14 分行打印字符 ‘1’ 、 ‘2’ 、 ‘3’ 、 ‘4’ 、 ‘5’
declare @x int
select @x = 1
label_1
print @x
select @x = @x + 1
while @x < 6
goto label_1
7 RETURN
语法如下
RETURN [ 整数值 ]
RETURN 命令用于结束当前程序的执行,返回到上一个调用它的程序或其它程序。在括号内可指定一个返回值。
例 4-15 declare @x int @y int
select @x = 1 @y = 2
if x>y
return 1
else
return 2
如果没有指定返回值, SQL Server 系统会根据程序执行的结果返回一个内定值,如
表 4-5 所示。
RETURN [ 整数值 ]
RETURN 命令用于结束当前程序的执行,返回到上一个调用它的程序或其它程序。在括号内可指定一个返回值。
例 4-15 declare @x int @y int
select @x = 1 @y = 2
if x>y
return 1
else
return 2
如果没有指定返回值, SQL Server 系统会根据程序执行的结果返回一个内定值,如
表 4-5 所示。
如果运行过程产生了多个错误,
SQL Server
系统将返回绝对值最大的数值;如果此时用户此时定义了返回值,则以返回用户定义的值。
RETURN
语句不能返回
NULL
值。