第8章 事务管理 数据库原理

上传人:飞*** 文档编号:6448403 上传时间:2017-08-08 格式:PPT 页数:68 大小:714KB
返回 下载 相关 举报
第8章 事务管理 数据库原理_第1页
第1页 / 共68页
第8章 事务管理 数据库原理_第2页
第2页 / 共68页
第8章 事务管理 数据库原理_第3页
第3页 / 共68页
第8章 事务管理 数据库原理_第4页
第4页 / 共68页
第8章 事务管理 数据库原理_第5页
第5页 / 共68页
点击查看更多>>
资源描述

《第8章 事务管理 数据库原理》由会员分享,可在线阅读,更多相关《第8章 事务管理 数据库原理(68页珍藏版)》请在金锄头文库上搜索。

1、事务管理,事务(Transaction)是用户定义的一个数据库操作序列,这些操作要么全做,要么全不做,是一个不可分割的工作单位事务和程序是两个概念在关系数据库中,一个事务可以是一条SQL语句,一组SQL语句或整个程序一个应用程序通常包含多个事务,SQL编程基础事务管理存储过程触发器,SQL编程基础,1、函数字符串函数日期和时间函数数学函数转换函数系统函数用户自定义函数,2、流程控制语句,(1)ifelse语句if |else |可以多层嵌套,(2)beginend 语句begin |nend(3)whilecontinue.break语句while break|continue,goto la

2、bel程序中有一行语句以label:开头例 利用goto语句求1加到5的总和。分析:(1)需要两个变量存储变量值和和值,用select语句赋初值分别为1和0(2)goto执行完一次以后转到label_1处循环执行(3)经过5次循环,求出结果,3、goto语句,declare count int,sum int /*声明变量*/select count=1,sum=0 /*变量赋初值*/label_1: /*循环标识位置*/select sum=sum+count /*循环部分select count=count+1 */if count=5 /*条件判断语句*/goto label_1sele

3、ct sum,count /*查询输出结果*/,4、return语句,无条件终止查询或存储过程,位于return语句后的程序将不会被执行。return ,5、打印输出语句,print |例 利用print语句判断变量值declare sum int /*声明变量*/select sum=5 /*变量赋初始值*/if sum=5 /*ifelse语句*/ print sum值不大于5 /*输出结果语句*/else print sum大于5,6、注释语句,(1)整块注释/*/(2)从行的后部分注释-,事务管理,事务管理语句:begin transaction /*事务开始*/commit tran

4、saction /*提交事务*/事务只使用于数据修改语句在提交事务之前可以取消事务并撤消对数据的修改,提交之后不能取消;rollback transaction savepoint_namesavepoint_name:标记事务回滚的保存点,例 建立一个事务,将course表中cno字段为1的记录的cname值更改为“大学英语”begin transactionupdate course /*更改表中数据*/set cname=大学英语where cno=1commit transaction事务执行后,可以使用查询语句查询修改后的表select * from course where cno

5、=1,例 建立一个事务,用来更改course表中cno为1以及cno为2的记录的cname字段的值,分别更改为“大学英语”和“线性代数”,并回滚到事务保存点,并查看事务的执行结果。(1)建立事务begin transactionsave transaction Aupdate course set cname=大学英语 where cno=1save transaction Bupdate course set cname=线性代数 where cno=2rollback transaction Bcommit transaction,(2)查看事务执行select * from course

6、where cno=1select * from course where cno=2,存储过程,SQL Server提供了一种方法,它可以将一些固定的操作集中起来由SQL Server数据库服务器来完成,以实现某个任务,这种方法就是存储过程。在SQL Server中存储过程分为两类:即系统存储过程和用户自定义的存储过程。 存储过程和视图的区别:视图是封装好的select语句,存储过程是sql语句。,创建存储过程,在SQL Server中,可以使用三种方法创建存储过程 :使用创建存储过程向导创建存储过程。利用SQL Server 企业管理器创建存储过程。使用CREATE PROCEDURE命令

7、创建存储过程。,创建存储过程时,需要确定存储过程的三个组成部分:,所有的输入参数以及传给调用者的输出参数。被执行的针对数据库的操作语句,包括调用其它存储过程的语句。返回给调用者的状态值,以指明调用是成功还是失败。,1. 使用CREATE PROCEDURE命令创建存储过程,创建存储过程前,应该考虑下列几个事项: 不能将 CREATE PROCEDURE 语句与其它 SQL 语句组合到单个批处理中。创建存储过程的权限默认属于数据库所有者,该所有者可将此权限授予其他用户。存储过程是数据库对象,其名称必须遵守标识符规则。只能在当前数据库中创建存储过程。一个存储过程的最大尺寸为128M。,使用CREA

8、TE PROCEDURE创建存储过程的语法形式如下:,create procedure ;版本号 =outputwith recompile|encryption| recompile,encryption for replication as ,用CREATE PROCEDURE创建存储过程的语法参数的意义如下:,过程名:用于指定要创建的存储过程的名称。 版本号:该参数是可选的整数,它用来对同名的存储过程分组,以便用一条 DROP PROCEDURE 语句即可将同组的过程一起除去。 参数名:过程中的参数。在 CREATE PROCEDURE 语句中可以声明一个或多个参数。 参数类型:用于指定

9、参数的数据类型。 Default:用于指定参数的默认值。 OUTPUT:表明该参数是一个返回参数。,RECOMPILE:重编译,表明 SQL Server 不会保存该存储过程的执行计划 。即要求每次执行都要对过程重编译和优化,并创建新的查询计划。ENCRYPTION :表示 SQL Server 加密了 syscomments 表(系统表),该表的text字段是包含 CREATE PROCEDURE 语句的存储过程文本。 FOR REPLICATION:用于指定不能在订阅服务器上执行为复制创建的存储过程。 AS:用于指定该存储过程要执行的操作。sql语句:是存储过程中要包含的任意数目和类型的

10、Transact-SQL 语句。,运行存储过程,execute 参数名=outputwith recompile,例:创建存储过程,1. 建立不带参数的存储过程建立一个名为“全部学生”的存储过程,用来查询student表的所有记录create procedure 全部学生as select *from student执行不带参数的execute 语句Use StuCouDbGoExecute 全部学生,2.建立带参数的存储过程(1) 建立一个名为”按系查询”的存储过程,查询某个系的全体学生信息.create procedure 系别查询 stu_dept varchar(10) as sele

11、ct * from student where dept=stu_dept 执行带参数的execute语句 execute 系别查询 计算机系,sno sname ssex sage dept98001 王芳 女21计算机系 98002 李兵 男20计算机系,(2) 建立一个名为”成绩查询”存储过程,根据姓名和课程号查询成绩.Create procedure 成绩查询 sname char(20),cno char(4)As Select sname,cno,markFrom student join grade on student.sno=grade.snoWhere sname=snam

12、e and cno=cno带参数的execute语句 execute 成绩查询 sname,cno,3.带输出参数的存储过程create procedure mathadd m1 int,m2 int, result int output as select result=m1+m2调用带参数的存储过程Declare answer intExecute mathadd 8,10,answer outputSelect answer,1. 使用创建存储过程向导创建存储过程,在企业管理器中,选择工具菜单中的向导选项,选择“创建存储过程向导” ,则出现欢迎使用创建存储过程向导对话框。根据图提示可完成

13、创建存储过程。,新建SQL Server组,欢迎使用创建存储过程向导对话框,选择数据库对话框,选择数据库对象对话框,完成创建存储过程向导对话框,编辑存储过程属性对话框,编辑存储过程SQL对话框,2. 使用SQL Server 企业管理器创建存储过程,()在SQL Server企业管理器中,选择指定的服务器和数据库,用右键单击要创建存储过程的数据库,在弹出的快捷菜单中选择“新建”选项,再选择下一级菜单中的“存储过程”选项,如图5-77所示;或者用右键单击存储过程图标,从弹出的快捷菜单中选择“新建存储过程”选项,如图5-78所示。均会出现创建存储过程对话框。()在文本框中可以输入创建存储过程的T_

14、SQL语句,单击“检查语法”,则可以检查语法是否正确;单击“确定”按钮,即可保存该存储过程。如果要设置权限,单击“权限”按钮。,选择新建存储过程对话框(1),选择新建存储过程对话框(2),新建存储过程对话框,设置权限对话框,查看和修改存储过程,查看存储过程 存储过程被创建之后,它的名字就存储在系统表sysobjects中,它的源代码存放在系统表syscomments中。可以使用使用企业管理器或系统存储过程来查看用户创建的存储过程。,(1)使用企业管理器查看用户创建的存储过程,在企业管理器中,打开指定的服务器和数据库项,选择要创建存储过程的数据库,单击存储过程文件夹,此时在右边的页框中显示该数据库的所有存储过程。用右键单击要查看的存储过程,从弹出的快捷菜单中选择属性选项,此时便可以看到存储过程的源代码。,(2)使用系统存储过程来查看用户创建的存储过程,可供使用的系统存储过程如下:(1) sp_help:用于显示存储过程的参数及其数据类型sp_help objname= name参数name为要查看的存储过程的名称。 (2) sp_helptext:用于显示存储过程的源代码 sp_helptext objname= name参数name为要查看的存储过程的名称。,

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 中学教育 > 其它中学文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号