当前位置:七道奇文章资讯数据防范MSSQL防范
日期:2011-05-02 15:21:00  来源:本站整理

SQL Server数据库技术(16)[MSSQL防范]

赞助商链接



  本文“SQL Server数据库技术(16)[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

Transact-SQL 语言利用的流程掌握号令与常见的程序计划语言近似主要有以下几种掌握号令.

4.6.1 IF…ELSE
其语法以下:
IF <条件表达式>
<号令行或程序块>
[ELSE [条件表达式]
<号令行或程序块>]
此中<条件表达式>可以是各种表达式的组合,但表达式的值必须是逻辑值"真"或"假".ELSE子句是可选的,最简单的IF语句没有ELSE子句部份.IF…ELSE用来判断当某一条件成立时履行某段程序,条件不成立时履行另一段程序.假如不利用程序块,IF或ELSE只能履行一条号令.IF…ELSE可以举行嵌套.

例4-9
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级.

4.6.2 BEGIN…END
其语法以下:
BEGIN
<号令行或程序块>
END
BEGIN…END用来设定一个程序块,将在BEGIN…END内的全部程序视为一个单元履行BEGIN…END常常在条件语句,如IF…ELSE中利用.在BEGIN…END中可嵌套别的的BEGIN…END来定义另一程序块.

4.6.3 CASE
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子句时,只运行第一个匹配的子名.

4.6.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
例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

4.6.5 WAITFOR
其语法以下:
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

4.6.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

4.6.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 所示.


假如运行历程产生了多个错误,SQL Server系统将返回绝对值最大的数值;假如此时用户此时定义了返回值,则以返回用户定义的值.RETURN语句不能返回NULL值.

  以上是“SQL Server数据库技术(16)[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • Windows 搭配 IIS7 PHP MySQL 环境
  • sqlserver索引的原理及索引成立的注意事项小结
  • SQL Join的一些总结(实例)
  • SQL的Join利用图解教程
  • SQL中JOIN和UNION辨别、用法及示例介绍
  • 关于SQL中CTE(公用表表达式)(Common Table Expression)的总结
  • mysql Out of memory (Needed 16777224 bytes)的错误办理
  • mysql提醒[Warning] Invalid (old?) table or database name问题的办理办法
  • mysql启用skip-name-resolve情势时呈现Warning的处理办法
  • mysql启用skip-name-resolve情势时呈现Warning的处理办法
  • MySQL Order By语法介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .