39. SQL -- 批处理及流程控制语句(1)

批处理及流程控制语句

批处理:(批处理语句,简称批语句): 是一组一起提交给SQL Server执行的SQL语句.当执行批处理语句的时候,SQL Server将批处理语句编译到一个称之为执行计划的可执行单元这有助于节省执行时间!

假如您必须执行10个SQL语句且你正在一个个的发送10个请求并执行它们,这个过程很浪费时间.且他们不能一起被执行!但你可以在一个批处理中执行所有的这10个SQL语句,且执行过程将变得很快,因为所有的SQL语句都一起被发送到SQL Server的服务器!

创建批处理语句:

T--SQL 语句 1

T--SQL 语句 2

T--SQL 语句 3

T--SQL 语句 n

go

注意: go是一个命令,它指定批处理的结果,并且发送SQL 语句到一个SQL Server实例..

当批处理被提交到SQL Server中,它被编译以创建一个执行计划.如果发生任何编译错误:

(1)语法错误,则执行计划不被创建,故批处理中没有语句被执行.(2)但执行计划创建之后,如果发生运行时错误,批处理的执行停止.但遇到运行时错误的语句之前执行的语句不受影响...

创建批处理语句的限制:

a) 不能在一个批语句中定义和使用check约束

b) 不能在一个批语句中撤销对象并重新创建它们

c) 不能在一个批语句中改变表和引用新列

d) 若在一个批语句中存在语法错误,则整个批都不执行

e) 可以使用go语句结束一个批语句,但go并不是T--SQL语句..

DEMO:

use demo_db

go

print ‘table timerecords infor‘

select * from timerecords

where clock_id = ‘105‘

print ‘emp_id count‘

select COUNT(emp_id) as count,CONVERT(char(10),sign_time,121) as sign_time

from timerecords

group by CONVERT(char(10),sign_time,121)

order by CONVERT(char(10),sign_time,121)

go

--PRINT语句用于显示charvarchar类型,或可自动转换为字符串类型的数据。

变量:

变量分为局部变量及全局变量

全局变量:

全局变量在整个SQL Server系统内使用。存储的通常是SQL Server的配置设定值和统计数据。在使用全局变量时应该注意以下几点:全局变量是在服务器级定义的。用户只能使用预先定义的全局变量。引用全局变量时,必须以标记符―@@‖开头。全局变量对用户来说是只读的。局部变量的名称不能与全局变量的名称相同全局变量是SQL Server系统内部使用的变量,其作用范围并不仅仅局限于某一程序,而是任何程序均可以随时调用。全局变量通常存储一些SQL Server的配置设定值和统计数据。用户可以在程序中用全局变量来测试系统的设定值或者是ransact-SQL命令执行后的状值。

使用全局变量时应该注意以下几点:

①全局变量不是由用户的程序定义的,它们是在服务器级定义的。

②用户只能使用预先定义的全局变量。

③引用全局变量时,必须以标记符―@@‖开头。

④局部变量的名称不能与全局变量的名称相同,否则会在应用程序中出现不可预测的结果。

一些常用的全局变量统计:

全局变量 作用

@@CONNECTIONS 返回自上次启动以来连接或试图连接的次数。

@@CURSOR_ROWS 返回连接上最后打开的游标中当前存在的合格行的数量(返回被打开的

游标中还未被读取的有效数据行的行数)

@@DATEFIRST 返回每周第一天的数字

@@ERROR 返回最后执行的SQL 语句的错误代码

@@FETCH_STATUS 返回被 FETCH 语句执行的最后游标的状态,而不是任何当前被连接打

开的游标的状态

@@IDENTITY 返回最后插入的标识值

@@LANGID 返回当前所使用语言的本地语言标识符(ID)。

@@LANGUAGE 返回当前使用的语言名。

@@LOCK_TIMEOUT 返回当前会话的当前锁超时设置,单位为毫秒。

@@PROCID 返回当前过程的存储过程标识符 (ID) 。

@@ROWCOUNT 返回受上一语句影响的行数。

@@SERVERNAME 返回运行 的本地服务器名称。

@@SPID 返回当前用户进程的服务器进程标识符 (ID)。

@@TRANCOUNT 返回当前连接的活动事务数。

@@VERSION 返回当前安装的日期、版本和处理器类型。

@@CPU_BUSY 返回自SQL Server 最近一次启动以来CPU 的工作时间其单位为毫秒

@@DATEFIRST 返回使用SET DATEFIRST 命令而被赋值的DATAFIRST 参数值SET

DATEFIRST,命令用来指定每周的第一天是星期几

@@DBTS 返回当前数据库的时间戳值必须保证数据库中时间戳的值是惟一的

@@ERROR 返回执行Transact-SQL 语句的错误代码

@@FETCH_STATUS 返回上一次FETCH 语句的状态值

@@IDLE 返回自SQL Server 最近一次启动以来CPU 处于空闭状态的时间长短

单位为毫秒

@@IO_BUSY 返回自SQL Server 最近一次启动以来CPU 执行输入输出操作所花费

的时间其单位为毫秒

@@LANGID 返回当前所使用的语言ID 值

@@LANGUAGE 返回当前使用的语言名称

@@LOCK_TIMEOUT 返回当前会话等待锁的时间长短其单位为毫秒

@@MAX_CONNECTIONS 返回允许连接到SQL Server 的最大连接数目

@@MAX_PRECISION 返回decimal 和numeric 数据类型的精确度

@@NESTLEVEL 返回当前执行的存储过程的嵌套级数初始值为0

@@OPTIONS 返回当前SET 选项的信息

@@PACK_RECEIVED 返回SQL Server 通过网络读取的输入包的数

@@PACK_SENT 返回SQL Server 写给网络的输出包的数目

@@PACKET_ERRORS 返回网络包的错误数目

@@PROCID 返回当前存储过程的ID 值

@@REMSERVER 返回远程SQL Server 数据库服务器的名称

@@SERVICENAME 返回SQL Server 正运行于哪种服务状态之下如MSSQLServer

MSDTC SQLServerAgent

@@SPID 返回当前用户处理的服务器处理ID 值

@@TEXTSIZE 返回SET 语句的TEXTSIZE 选项值SET 语句定义了SELECT 语句中

text 或image 数据类型的最大长度基本单位为字节

@@TIMETICKS 返回每一时钟的微秒数

@@TOTAL_ERRORS 返回磁盘读写错误数目

@@TOTAL_READ 返回磁盘读操作的数目

@@TOTAL_WRITE 返回磁盘写操作的数目

@@TRANCOUNT 返回当前连接中处于激活状态的事务数目

DEMO:

Select @@connections

返回结果:

9456

DEMO:利用全局变量查看sql server的版本、当前所使用的sql server服务器的名称

以及所使用的服务器的服务名称等信息。

print ‘目前所用sql server的版本信息‘

print @@version --版本

print ‘目前所用sql server服务器的名称:‘+ @@servername --服务器的名称

print ‘目前所用服务器的服务名称:‘+ @@servicename --服务名称

go

返回结果:

目前所用sql server的版本信息

Microsoft SQL Server 2008 (RTM) -10.0.1600.22 (X64)

Jul 9 2008 14:17:44

Copyright (c) 1988-2008 MicrosoftCorporation

Enterprise Edition (64-bit) onWindows NT 6.1 <X64> (Build 7600: ) (VM)

目前所用sql server服务器的名称:SQL2008

目前所用服务器的服务名称:MSSQLSERVER

局部变量:

局部变量是一个能够拥有特定数据类型的对象,它的作用范围仅限制在程序内部。局部变量可以作为计数器来计算循环执行的次数,或是控制循环执行的次数。另外,利用局部

变量还可以保存数据值,以供控制流语句测试以及保存由存储过程返回的数据值等。局部变量被引用时要在其名称前加上标志―@‖,而且必须先用DECLARE命令定义后才可以使用。利用局部变量还可以保存程序执行过程中的中间数据值,保存由存储过程返回的数据值等。局部变量的名称以一个@字符开始,由用户自己定义和赋值局部变量的定义:必须先用DECLARE命令定义后才可以使用。

DECLAER {@local_variabledata_type} […n]

局部变量的赋 .方法 : 局部变量名 数据类型

SET {{ @local_variable = expression }

或者:

SELECT{ @local_variable = expression } [ ,...n ] 表达式

DEMO:声明两个局部变量,并对它们进行赋值,然后将变量的值显示出来。代码如下:

declare@nowdate char(10),@disp varchar(30)

set @nowdate=getdate()

set @disp=‘现在的日期为‘

print@disp+@nowdate

返回:

现在的日期为8 2011

流程控制语句

流程控制语句是指那些用来控制程序执行和流程分支的命令,在SQL Server 2000中,流程控制语句主要用来控制SQL语句、语句块或者存储过程的执行流程。SQL Server中程序流程结构:

a) 顺序型结构

b) 判断选择型结构 if..else语句和case语句

c) 循环控制结构 while语句...

 

 

SQLServer中程序语句:

a) 注释符

b) 批处理

c) 块语句Begin...End

d) 判断语句if...else语句

e)if..exists语句

f)case语句

g)print语句

h)WHILE…CONTINUE…BREAK语句

i)GOTO语句

j)WAITFOR语句

k)RETURN语句

A、块语句Begin...End

BEGINEND语句能够将多个Transact-SQL语句组合成一个语句块,并将它们视为一个单元处理。在条件语句和循环等控制流程语句中,当符合特定条件便要执行两个或者多个语句时,就需要使用BEGINEND语句,将多个T-sql语句组合成一个语句块。

 

EGINEND 语句用于下列情况:

WHILE 循环需要包含语句块。

CASE 函数的元素需要包含语句块。

IF 或 ELSE 子句需要包含语句块。

语法:

BEGIN

{ sql_statement |

statement_block }

END

说明:

a)Begin...End用来设定一个程序块,在它里面所有程序将被视为一个单元执行

b) 尽管Begin...End几乎可以用在程序中的任何地方,但它最常见的用法是和while或if..else组合使用...

c) 在Begin...End中可以嵌套另外的Begin--End来定义另一程序块..

Begin...End语句块与其它编程语言有所不同的就是,在语句块中声明的SQL变量其作用域是在声明后的整个批中,而不是仅仅局限于这个语句块.但在大多数编程语言中这种写法的错误的.

DEMO

declare@id int --声明SQL局部变量

set @id=1 --使用set语句为该SQL变量赋值

if(@id=1)

Begin--Begin语句块

declare@str varchar(10) --声明SQL局部变量

set @str= ‘bcy‘ --使用set语句为该SQL变量赋值

End

select‘[‘+@str+‘]‘

go

DEMO:创建一个测试表,并循环写入500条数据,使用newid()

declare@num int =1

while@num <=500

begin

print‘test‘

set @num=@num+1

end

判断语句if...else语句

IF…ELSE语句是条件判断语句,其中:ELSE子句是可选的,简单的IF语句没有ELSE子句部分。IF…ELSE语句用来判断当某一条件成立时执行某段程序,条件不成立时执行另一段程序。SQL Server允许嵌套使用IF…ELSE语句,而且嵌套层数没有限制。

注意:如果布尔表达式中包含一个SELECT语句,则必须使用圆括号扩起来。

如果满足条件,则在 IF 关键字及其条件之后执行Transact-SQL 语句:布尔表达式返回 TRUE。可选的 ELSE 关键字引入另一个 Transact-SQL 语句,当不满足 IF 条件时就执行该语句:布尔表达式返回 FALSE。IF...ELSE 构造可用于批处理、存储过程和即时查询。当此构造用于存储过程时,通常用于测试某个参数是否存在。

语法:

IFELSE 语句:

IFBoolean_expression 条件表达式

{sql_statement | statement_block } 语句序列

[ ELSE

{sql_statement | statement_block } ]

IF <条件表达式>

<命令行或程序块>

[ELSE [条件表达式]

<命令行或程序块>]

IFELSE 可以嵌套使用,最多可嵌套32 级

DEMO1:在uspGetList 存储过程的输出中使用了 IFELSE。该存储过程在创建存储过

程中定义。在此示例中,该存储过程返回标价低于 700 美元的自行车清单。这将导致执

行第一个 PRINT 语句

DECLARE@compareprice money, @cost money

EXECUTEProduction.uspGetList ‘%Bikes%‘, 700,

@comparepriceOUT,

@costOUTPUT

IF @cost <= @compareprice

BEGIN

PRINT‘These products canbe purchased for less than

$‘+RTRIM(CAST(@compareprice AS varchar(20)))+‘.‘

END

ELSE

PRINT‘The prices for allproducts in this category exceed

$‘+ RTRIM(CAST(@compareprice AS varchar(20)))+‘.‘

DEMO2:创建一个随机数/2,看是否余数为0,若为0,返回a,若不为0,返回b

declare@num int

set @num =(convert(int,RANd(11)*100000))

if @num % 2=0

print‘a‘

else

print‘b‘

DEMO3:

Usemarket

if (select 库存量

fromgoods

where货品名称=彩电‘)<30

Begin

[email protected] int

[email protected]=(select 库存量 from goods

where货品名称=彩电‘)

Print彩电的库存量为:‘+cast(@number1 as char(3))

Print该商品库存量已不足,提醒进货!‘

end

/*cast函数用于将某种数据类型的表达式转换为另一种数据类型。*/

DEMO4:

Usemarket

ifexists(select *

fromgoods

where状态=0) --判断库存量是否为空

Begin

select货品名称、库存量

fromgoods

where状态=0

Print‘商品尚不能出售’

end

Else

Begin

select货品名称、库存量

fromgoods

where状态=1

Print‘该商品可以出售!’

end

 

if exists语句

if exists 语句用来检测数据是否存在,而不考虑与之匹配的总共行数..

语法:

if [not] exists (select 子查询)

SQL 语句或语句块1

[else]

SQL 语句或语句块2 ...

说明:

a) SQL Server 服务器只要找到第一个匹配的行(记录),就停止执行select 子查询语句.

b) if 语句最多可以嵌套150 层..

DEMO:

if exists(select *

from student

where name= ‘杨育键‘

and

)

select ‘杨育键存在! ‘

else

select ‘杨育键不存在!‘

时间: 2024-10-11 13:11:56

39. SQL -- 批处理及流程控制语句(1)的相关文章

40. SQL -- 批处理及流程控制语句(2)

  CASE语句 CASE函数可以计算多个条件式,并将其中一个符合条件的结果表达式返回.CASE函数按照使用形式的不同,可以分为简单CASE函数和搜索CASE函数. 简单CASE 函数将某个表达式与一组简单表达式进行比较以确定结果. CASE 搜索函数计算一组布尔表达式以确定结果. 简单CASE函数: 简单CASE表达式将一个测试表达式与一组简单表达式进行比较,如果某个简单表达式与测试表达式的值相等,则返回相应结果表达式的值.When子句提供测试值,并将When子句所指定的结果表达式返回.测试表

Oracle之PL/SQL编程_流程控制语句

选择语句 1. if...then 语句 语法: if < condition_expression > then plsql_sentence end if; condition_expression:表示一个条件表达式,其值为 true 时,程序会执行 if 下面的 PL/SQL 语句: 如果其值为 false,则程序会跳过if 下面的语句而 直接执行 end if 后边的语句. plsql_sentence:condition_expression 为 true 时,要执行的语句. 2.

29. SQL -- T-SQL 流程控制语句

T-SQL 流程控制语句 Transact-SQL 语言提供了一些可以用于改变语句执行顺序的命令,称为流程控制语句.流程控制语句允许用户更好地组织存储过程中的语句,方便地实现程序的功能.流程控制语句与常见的程序设计语言类似,主要包含以下几种. T-SQL 的流程控制语句: IF-ELSE BEGIN-END CASE WHILE-CONTINUE-BREAK WAITFOR GOTO RETURN IFELSE 语句: 指定 Transact-SQL 语句的执行条件.如果满足条件,则在 IF 关

[推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆)

原文:[推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆) [推荐]ORACLE PL/SQL编程详解之三: PL/SQL流程控制语句(不给规则,不成方圆) ——通过知识共享树立个人品牌. 继上五篇: [顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功) [推荐]ORACLE PL/SQL编程之四:把游标说透(不怕做不到,只怕想不到) [推荐]ORACLE PL/SQL编程之五:异常错误处理(知已知彼.百战不

PL/SQL之--流程控制语句

一.简介 像编程语言一样,oracle PL/SQL也有自己的流程控制语句.通过流程控制语句,我们可以在PL/SQL中实现一下比较复杂的业务逻辑操作.而无需到程序中去控制,在一定程度上提高了效率,这也是PL/SQL的强大之处.PL/SQL流程控制语句有如下几种: 控制语句: 包括IF 语句.CASE语句 循环语句: 包括LOOP语句, WHILE语句.FOR语句 顺序语句: 包括GOTO语句 二.语句种类 1.控制语句 a.IF语句 语法如下: IF 条件语句 TEHN 执行语句 ELSIF 条

SQL SERVER中的流程控制语句

流程控制语句 是指用来控制程序执行和流程分至点额命令,一般指的是逻辑计算部分的控制. 1.Begin End语句 封装了多个T-SQL语句组合,将他们组成一个单元来处理.一般在条件查询或者循环等控制流程语句中,要查询满足特定条件的操作时会用到.Begin--end可以嵌套使用. 语法如下: begin --<sql语句或程序块> end 例子 begin --<sql语句或程序块> select * from StudentInfo update StudentInfo set m

PL/SQL流程控制语句

PL/SQL流程控制语句介绍PL/SQL的流程控制语句, 包括如下三类:控制语句: IF 语句循环语句: LOOP语句, EXIT语句顺序语句: GOTO语句, NULL语句①if语句 IF <布尔表达式> THEN PL/SQL 和SQL语句; ELSIF< 其它布尔表达式> THEN 其它语句; ELSIF< 其它布尔表达式> THEN 其它语句; ELSE 其它语句; END IF; 例: declare v_emp_name employees.last_nam

MS SQL 流程控制语句

Declare   myCursor   cursor   For     Select   *   from   table1 open   myCursor         Fetch   next   From   myCursor   into   @变量     While   @@FETCH_STATUS   =0     begin           --处理单条记录           Fetch   next   From   myCursor     end Close  

PL/SQL程序设计、流程控制

PL/SQL是 Procedure Language & Structured Query Language 的缩写 PL/SQL是对SQL语言存储过程语言的扩展 PL/SQL程序由三个块组成,即声明部分.执行部分.异常处理部分. 在语句块的声明部分对变量声明,声明一个变量的语法是: variable_name [ constant ] type [ not null ] [:=value]其中: variable_name 为变量名 type 为类型 value 为变量的初值 PL/SQL结构