




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、数据库系统概论数据库系统概论An Introduction to An Introduction to Database SystemDatabase System 第八章第八章 数据库编程数据库编程第八章 数据库编程8.1 嵌入式嵌入式SQL8.2 存储过程存储过程8.3 ODBC编程编程8.1 嵌入式SQLvSQL言语提供了两种不同的运用方式:v交互式v嵌入式v为什么要引入嵌入式SQLvSQL言语是非过程性言语v事务处置运用需求高级言语v这两种方式细节上有差别,在程序设计的环境下,SQL语句要做某些必要的扩展8.1 嵌入式SQL8.1.1 嵌入式嵌入式SQL的处置过程的处置过程8.1.2
2、嵌入式嵌入式SQL语句与主言语之间的通讯语句与主言语之间的通讯8.1.3 不运用游标的不运用游标的SQL语句语句8.1.4 运用游标的运用游标的SQL语句语句8.1.5 动态动态SQL8.1.6 小结小结8.1.1 嵌入式SQL的处置过程v主言语v嵌入式SQL是将SQL语句嵌入程序设计言语中,被嵌入的程序设计言语,如C、C+、Java,称为宿主言语,简称主言语。v处置过程v预编译方法嵌入式SQL的处置过程续 主言语程序 含ESQL语句RDBMS的预处置程序ESQL语句转换为函数调用主言语编译程序目的言语程序ESQL根本处置过程嵌入式SQL的处置过程续 v为了区分SQL语句与主言语语句, 一切S
3、QL语句必需加前缀EXEC SQL,以(;)终了: vEXEC SQL ;8.1 嵌入式SQL8.1.1 嵌入式嵌入式SQL的处置过程的处置过程8.1.2 嵌入式嵌入式SQL与主言语的通讯与主言语的通讯8.1.3 不运用游标的不运用游标的SQL语句语句8.1.4 运用游标的运用游标的SQL语句语句8.1.5 动态动态SQL8.1.6 小结小结8.1.2 嵌入式SQL语句与主言语之间的通讯v将SQL嵌入到高级言语中混合编程,程序中会含有两种不同计算模型的语句vSQL语句v 描画性的面向集合的语句v 担任支配数据库v高级言语语句v 过程性的面向记录的语句v 担任控制程序流程v它们之间应该如何通讯?
4、嵌入式SQL语句与主言语之间的通讯续 v数据库任务单元与源程序任务单元之间的通讯:v1. SQL通讯区v向主言语传送SQL语句的执行形状信息v使主言语可以据此控制程序流程v2. 主变量v主言语向SQL语句提供参数v将SQL语句查询数据库的结果交主言语进一步处置v3. 游标v处理集合性操作言语与过程性操作言语的不匹配一、SQL通讯区vSQLCA: SQL Communication AreavSQLCA是一个数据构造vSQLCA的用途vSQL语句执行后,RDBMS反响给运用程序信息v 描画系统当前任务形状v 描画运转环境v这些信息将送到SQL通讯区SQLCA中v运用程序从SQLCA中取出这些形状
5、信息,据此决议接下来执行的语句SQL通讯区vSQLCA运用方法v定义SQLCAv 用EXEC SQL INCLUDE SQLCA定义v运用SQLCAvSQLCA中有一个存放每次执行SQL语句后前往代码的变量SQLCODEv假设SQLCODE等于预定义的常量SUCCESS,那么表示SQL语句胜利,否那么表示出错v运用程序每执行完一条SQL 语句之后都应该测试一下SQLCODE的值,以了解该SQL语句执行情况并做相应处置二、主变量 v主变量v嵌入式SQL语句中可以运用主言语的程序变量来输入或输出数据v在SQL语句中运用的主言语程序变量简称为主变量Host Variable主变量续 v主变量的类型v
6、输入主变量v输出主变量v一个主变量有能够既是输入主变量又是输出主变量主变量续 v指示变量:v一个主变量可以附带一个指示变量Indicator Variablev什么是指示变量v是一个整型变量,用来指示所指主变量的值或条件。v指示变量的用途v 可以指示输入主变量能否为空值,指示输出主变量能否为空值,值能否被截断。主变量续 v在SQL语句中运用主变量和指示变量的方法v1) 阐明主变量和指示变量vBEGIN DECLARE SECTIONv. v. (阐明主变量和指示变量)v.vEND DECLARE SECTION主变量续 2) 运用主变量阐明之后的主变量可以在SQL语句中任何一个可以运用表达式的
7、地方出现为了与数据库对象名表名、视图名、列名等区别,SQL语句中的主变量名前要加冒号:作为标志3) 运用指示变量 指示变量前也必需加冒号标志 必需紧跟在所指主变量之后主变量续 v在SQL语句之外(主言语语句中)运用主变量和指示变量的方法v可以直接援用,不用加冒号三、游标cursorv为什么要运用游标v SQL言语与主言语具有不同数据处置方式vSQL言语是面向集合的,一条SQL语句原那么上可以产生或处置多条记录v主言语是面向记录的,一组主变量一次只能存放一条记录v仅运用主变量并不能完全满足SQL语句向运用程序输出数据的要求v嵌入式SQL引入了游标的概念,用来协调这两种不同的处置方式 游标续v游标
8、v游标是系统为用户开设的一个数据缓冲区,存放SQL语句的执行结果v每个游标区都有一个名字v用户可以用SQL语句逐一从游标中获取记录,并赋给主变量,交由主言语进一步处置四、建立和封锁数据库衔接v建立数据库衔接 vEXEC SQL CONNECT TO target AS connection-name USER user-name; v target是要衔接的数据库效力器:v常见的效力器标识串,如: v包含效力器标识的SQL串常量 vDEFAULT v connect-name是可选的衔接名,衔接必需是一个有效的标识符 v 在整个程序内只需一个衔接时可以不指定衔接名v封锁数据库衔接 vEXEC
9、SQL DISCONNECT connection;v程序运转过程中可以修正当前衔接 :vEXEC SQL SET CONNECTION connection-name | DEFAULT;五、程序实例例1依次检查某个系的学生记录,交互式更新某些学生年龄。EXEC SQL BEGIN DEC LARE SECTION; /*主变量阐明开场*/ char deptname64;char HSno64;char HSname64; char HSsex64;int HSage;int NEWAGE;EXEC SQL END DECLARE SECTION; /*主变量阐明终了*/long SQLC
10、ODE;EXEC SQL INCLUDE sqlca; /*定义SQL通讯区*/程序实例续int main(void) /*C言语主程序开场*/int count = 0;char yn; /*变量yn代表yes或no*/printf(Please choose the department name(CS/MA/IS): ); scanf(%s, deptname); /*为主变量deptname赋值*/EXEC SQL CONNECT TO TESTlocalhost:54321 USER SYSTEM /MANAGER; /*衔接数据库TEST*/EXEC SQL DECLARE SX
11、CURSOR FOR /*定义游标*/SELECT Sno, Sname, Ssex, Sage /*SX对应语句的执行结果*/FROM StudentWHERE SDept = :deptname;EXEC SQL OPEN SX; /*翻开游标SX便指向查询结果的第一行*/程序实例续for ( ; ; ) /*用循环构造逐条处置结果集中的记录*/ EXEC SQL FETCH SX INTO :HSno, :HSname, :HSsex,:HSage; /*推进游标,将当前数据放入主变量*/if (sqlca.sqlcode != 0) /* sqlcode != 0,表示操作不胜利*/b
12、reak; /*利用SQLCA中的形状信息决议何时退出循环*/if (count+ = 0) /*假设是第一行的话,先打出行头*/ printf (n%-10s %-20s %-10s %-10sn, Sno, Sname, Ssex, Sage); printf (%-10s %-20s %-10s %-10dn, HSno, HSname, HSsex, HSage); /*打印查询结果*/ printf (UPDATE AGE(y/n)?); /*讯问用户能否要更新该学生的年龄*/ do scanf(%c,&yn); while (yn != N & yn != n &a
13、mp; yn != Y & yn != y);程序实例续if (yn = y | yn = Y) /*假设选择更新操作*/ printf(INPUT NEW AGE:); scanf(%d,&NEWAGE); /*用户输入新年龄到主变量中*/ EXEC SQL UPDATE Student /*嵌入式SQL*/SET Sage = :NEWAGEWHERE CURRENT OF SX ; /*对当前游标指向的学生年龄进展更新*/ EXEC SQL CLOSE SX; /*封锁游标SX不再和查询结果对应*/EXEC SQL COMMIT WORK; /*提交更新*/EXEC SQ
14、L DISCONNECT TEST; /*断开数据库衔接*/8.1 嵌入式SQL8.1.1 嵌入式嵌入式SQL的处置过程的处置过程8.1.2 嵌入式嵌入式SQL语句与主言语之间的通讯语句与主言语之间的通讯8.1.3 不运用游标的不运用游标的SQL语句语句8.1.4 运用游标的运用游标的SQL语句语句8.1.5 动态动态SQL8.1.6 小结小结8.1.3 不用游标的SQL语句v不用游标的SQL语句的种类v 阐明性语句v 数据定义语句v 数据控制语句v 查询结果为单记录的SELECT语句v 非CURRENT方式的增删改语句 不用游标的SQL语句续v一、查询结果为单记录的SELECT语句 v二、非
15、CURRENT方式的增删改语句一、查询结果为单记录的SELECT语句v这类语句不需求运用游标,只需求用INTO子句指定存放查询结果的主变量 v例2 根据学生号码查询学生信息。假设曾经把要查询的学生的学号赋给了主变量givensno。vEXEC SQL SELECT Sno,Sname,Ssex,Sage,Sdept INTO :Hsno, : Hname ,:Hsex,:Hage,:Hdeptv FROM Studentv WHERE Sno=:givensno;查询结果为单记录的SELECT语句续(1) INTO子句、WHERE子句和HAVING短语的条件表达式中均可以运用主变量(2)查询前
16、往的记录中,能够某些列为空值NULL。(3) 假设查询结果实践上并不是单条记录,而是多条记录,那么程序出错,RDBMS会在SQLCA中前往错误信息 查询结果为单记录的SELECT语句续例3 查询某个学生选修某门课程的成果。假设曾经把将要查询的学生的学号赋给了主变量givensno,将课程号赋给了主变量givencno。 EXEC SQL SELECT Sno,Cno,Grade INTO :Hsno,:Hcno,:Hgrade:Gradeid /*指示变量Gradeid*/ FROM SC WHERE Sno=:givensno AND Cno=:givencno;假设Gradeid 0,不论
17、Hgrade为何值,均以为该学生成果为空值。二、非CURRENT方式的增删改语句v在UPDATE的SET子句和WHERE子句中可以运用主变量,SET子句还可以运用指示变量 v例4 修正某个学生选修1号课程的成果。vEXEC SQL UPDATE SCv SET Grade=:newgrade /*修正的成果已赋给主变量*/v WHERE Sno=:givensno; /*学号赋给主变量givensno*/ 非CURRENT方式的增删改语句续例5 将计算机系全体学生年龄置NULL值。 Sageid=-1; EXEC SQL UPDATE Student SET Sage=:Raise :Sage
18、id WHERE Sdept= CS; 将指示变量Sageid赋一个负值后,无论主变量Raise为何值,RDBMS都会将CS系一切学生的年龄置空值 。等价于: EXEC SQL UPDATE Student SET Sage=NULL WHERE Sdept= CS;非CURRENT方式的增删改语句续例6 某个学生退学了,现要将有关他的一切选课记录删除掉。假设该学生的姓名已赋给主变量stdname。 EXEC SQL DELETE FROM SC WHERE Sno= (SELECT Sno FROM Student WHERE Sname=:stdname); 非CURRENT方式的增删改语
19、句续例7 某个学生新选修了某门课程,将有关记录插入SC表中。假设插入的学号已赋给主变量stdno,课程号已赋给主变量couno。 gradeid=-1; /*用作指示变量,赋为负值*/EXEC SQL INSERT INTO SC(Sno,Cno,Grade) VALUES(:stdno,:couno,:gr :gradeid); 由于该学生刚选修课程,成果应为空,所以要把指示变量赋为负值 8.1 嵌入式SQLv8.1.1 嵌入式嵌入式SQL的处置过程的处置过程v8.1.2 嵌入式嵌入式SQL语句与主言语之间的通讯语句与主言语之间的通讯v8.1.3 不运用游标的不运用游标的SQL语句语句v8.
20、1.4 运用游标的运用游标的SQL语句语句v8.1.5 动态动态SQLv8.1.6 小结小结8.1.4 运用游标的SQL语句v必需运用游标的SQL语句v查询结果为多条记录的SELECT语句vCURRENT方式的UPDATE语句vCURRENT方式的DELETE语句运用游标的SQL语句续v一、 查询结果为多条记录的SELECT语句v二、CURRENT方式的UPDATE和DELETE语句一、 查询结果为多条记录的SELECT语句v运用游标的步骤v1. 阐明游标v2. 翻开游标v3. 推进游标指针并取当前记录 v4. 封锁游标1. 阐明游标v运用DECLARE语句v语句格式vEXEC SQL DEC
21、LARE CURSORv FOR ;v功能v是一条阐明性语句,这时DBMS并不执行SELECT指定的查询操作。2. 翻开游标v运用OPEN语句v语句格式v EXEC SQL OPEN ;v功能v翻开游标实践上是执行相应的SELECT语句,把一切满足查询条件的记录从指定表取到缓冲区中v这时游标处于活动形状,指针指向查询结果集中第一条记录3.推进游标指针并取当前记录 v运用FETCH语句v语句格式v EXEC SQL FETCH NEXT|PRIOR|v FIRST|LAST FROM v INTO ,.;推进游标指针并取当前记录续v功能v指定方向推进游标指针,然后将缓冲区中的当前记录取出来送至主
22、变量供主言语进一步处置vNEXT|PRIOR|FIRST|LAST:指定推进游标指针的方式v NEXT:向前推进一条记录v PRIOR:向回退一条记录v FIRST:推向第一条记录v LAST:推向最后一条记录v 缺省值为NEXT4. 封锁游标v运用CLOSE语句v语句格式v EXEC SQL CLOSE ;v功能v封锁游标,释放结果集占用的缓冲区及其他资源v阐明v游标被封锁后,就不再和原来的查询结果集相联络v被封锁的游标可以再次被翻开,与新的查询结果相联络二、CURRENT方式的UPDATE语句和DELETE语句vCURRENT方式的UPDATE语句和DELETE语句的用途v 面向集合的操作
23、v 一次修正或删除一切满足条件的记录CURRENT方式的UPDATE语句和DELETE语句(续)假设只想修正或删除其中某个记录用带游标的SELECT语句查出一切满足条件的记录从中进一步找出要修正或删除的记录用CURRENT方式的UPDATE语句和DELETE语句修正或删除之UPDATE语句和DELETE语句中的子句: WHERE CURRENT OF 表示修正或删除的是最近一次取出的记录,即游标指针指向的记录 CURRENT方式的UPDATE语句和DELETE语句(续)v不能运用CURRENT方式的UPDATE语句和DELETE语句 :v当游标定义中的SELECT语句带有UNION或ORDER
24、 BY子句 v该SELECT语句相当于定义了一个不可更新的视图 嵌 入 式 SQLv8.1.1 嵌入式嵌入式SQL的处置过程的处置过程v8.1.2 嵌入式嵌入式SQL语句与主言语之间的通讯语句与主言语之间的通讯v8.1.3 不运用游标的不运用游标的SQL语句语句v8.1.4 运用游标的运用游标的SQL语句语句v8.1.5 动态动态SQLv8.1.6 小结小结 8.1.5 动态SQLv静态嵌入式SQLv静态嵌入式SQL语句可以满足普通要求 v无法满足要到执行时才可以确定要提交的SQL语句 v动态嵌入式SQLv允许在程序运转过程中暂时“组装SQL语句v支持动态组装SQL语句和动态参数两种方式 动态
25、SQL简介续v一、运用SQL语句主变量 v二、动态参数一、运用SQL语句主变量vSQL语句主变量:v程序主变量包含的内容是SQL语句的内容,而不是原来保管数据的输入或输出变量vSQL语句主变量在程序执行期间可以设定不同的SQL语句,然后立刻执行 运用SQL语句主变量续例9 创建根本表TESTEXEC SQL BEGIN DECLARE SECTION;const char *stmt = CREATE TABLE test(a int); /* SQL语句主变量 */EXEC SQL END DECLARE SECTION;. .EXEC SQL EXECUTE IMMEDIATE :stmt
26、; /* 执行语句 */二、动态参数v动态参数vSQL语句中的可变元素v运用参数符号(?)表示该位置的数据在运转时设定v和主变量的区别v动态参数的输入不是编译时完成绑定v而是经过 (prepare)语句预备主变量和执行(execute)时绑定数据或主变量来完成 动态参数续v运用动态参数的步骤v1.声明SQL语句主变量。v2.预备SQL语句(PREPARE)。v EXEC SQL PREPARE FROM ;v 3.执行预备好的语句(EXECUTE)vEXEC SQL EXECUTE INTO v USING ;动态参数续例10向TEST中插入元组。EXEC SQL BEGIN DECLARE
27、SECTION;const char *stmt = INSERT INTO test VALUES(?); /*声明SQL主变量 */EXEC SQL END DECLARE SECTION;. .EXEC SQL PREPARE mystmt FROM :stmt; /* 预备语句 */. .EXEC SQL EXECUTE mystmt USING 100; /* 执行语句 */EXEC SQL EXECUTE mystmt USING 200; /* 执行语句 */8.1 嵌入式SQL8.1.1 嵌入式嵌入式SQL的处置过程的处置过程8.1.2 嵌入式嵌入式SQL语句与主言语之间的通讯
28、语句与主言语之间的通讯8.1.3 不运用游标的不运用游标的SQL语句语句8.1.4 运用游标的运用游标的SQL语句语句8.1.5 动态动态SQL8.1.6 小结小结8.1.6 小 结v在嵌入式SQL中,SQL语句与主言语语句分工非常明确v SQL语句v直接与数据库打交道,取出数据库中的数据。v 主言语语句v控制程序流程v对取出的数据做进一步加工处置小结续vSQL言语是面向集合的,一条SQL语句原那么上可以产生或处置多条记录v主言语是面向记录的,一组主变量一次只能存放一条记录v仅运用主变量并不能完全满足SQL语句向运用程序输出数据的要求v嵌入式SQL引入了游标的概念,用来协调这两种不同的处置方式
29、第八章 数据库编程8.1 嵌入式嵌入式SQL8.2 存储过程存储过程8.3 ODBC编程编程8.2 存储过程vSQL-invoked routines:v存储过程(SQL-invoked procedure)v函数(SQL-invoked function)8.2 存储过程8.2.1 PL/SQL的块构造的块构造8.2.2 变量常量的定义变量常量的定义8.2.3 控制构造控制构造8.2.4 存储过程存储过程8.2.5 小结小结8.2.1 PL/SQL的块构造vPL/SQL :vSQL的扩展 v添加了过程化语句功能 v根本构造是块v块之间可以相互嵌套 v每个块完成一个逻辑操作 PL/SQL的块构
30、造续vPL/SOL块的根本构造:块的根本构造: v 1.定义部分定义部分v DECLARE v -变量、常量、游标、异常等变量、常量、游标、异常等 v定义的变量、常量等只能在该根本块中定义的变量、常量等只能在该根本块中运用运用v当根本块执行终了时,定义就不再存在当根本块执行终了时,定义就不再存在PL/SQL的块构造续vPL/SOL块的根本构造块的根本构造(续续):v 2.执行部分执行部分v BEGINv -SQL语句、语句、PL/SQL的流程控制语的流程控制语句句v EXCEPTIONv -异常处置部分异常处置部分 v END;8.2 存储过程8.2.1 PL/SQL的块构造的块构造8.2.2
31、 变量常量的定义变量常量的定义8.2.3 控制构造控制构造8.2.4 存储过程存储过程8.2.5 小结小结8.2.2 变量常量的定义1. PL/SQL中定义变量的语法方式是: 变量名 数据类型 NOT NULL:=初值表达式或 变量名 数据类型 NOT NULL初值表达式2. 常量的定义类似于变量的定义: 常量名 数据类型 CONSTANT :=常量表达式 常量必需求给一个值,并且该值在存在期间或常量的作用域内不能改动。假设试图修正它,PL/SQL将前往一个异常。3. 赋值语句 变量称号:=表达式8.2 存储过程8.2.1 PL/SQL的块构造的块构造8.2.2 变量常量的定义变量常量的定义8
32、.2.3 控制构造控制构造8.2.4 存储过程存储过程8.2.5 小结小结8.2.3 控制构造 vPL/SQL 功能:功能:v一、条件控制语句一、条件控制语句v二、循环控制语句二、循环控制语句 v三、错误处置三、错误处置 控制构造续v一、一、 条件控制语句条件控制语句v IF-THEN, IF-THEN-ELSE和嵌套的和嵌套的IF语句语句 v1. IF condition THENv Sequence_of_statements; v END IF v2. IF condition THENv Sequence_of_statements1; v ELSEv Sequence_of_stat
33、ements2; v END IF;v3. 在在THEN和和ELSE子句中还可以再包括子句中还可以再包括IF语句,即语句,即IF语句可以嵌套语句可以嵌套 控制构造续二、循环控制语句二、循环控制语句 LOOP, WHILE-LOOP和和FOR-LOOP 1. 最简单的循环语句最简单的循环语句LOOP LOOP Sequence_of_statements; END LOOP; 多数数据库效力器的多数数据库效力器的PL/SQL都提供都提供EXIT、BREAK或或LEAVE等循环终了语句,保证等循环终了语句,保证LOOP语句块可以终了。语句块可以终了。控制构造续2. WHILE-LOOP WHILE
34、 condition LOOP Sequence_of_statements;END LOOP;每次执行循环体语句之前,首先对条件进展求值每次执行循环体语句之前,首先对条件进展求值假设条件为真,那么执行循环体内的语句序列。假设条件为真,那么执行循环体内的语句序列。假设条件为假,那么跳过循环并把控制传送给下一个语句假设条件为假,那么跳过循环并把控制传送给下一个语句 3. FOR-LOOP FOR count IN REVERSEbound1 bound2 LOOP Sequence_of_statements;END LOOP;控制构造续v三、错误处置v假设PL/SQL在执行时出现异常,那么应该
35、让程序在产生异常的语句处停下来,根据异常的类型去执行异常处置语句 vSQL规范对数据库效力器提供什么样的异常处置做出了建议,要求PL/SQL管理器提供完善的异常处置机制 8.2 存储过程v8.2.1 PL/SQL的块构造的块构造v8.2.2 变量常量的定义变量常量的定义v8.2.3 控制构造控制构造v8.2.4 存储过程存储过程v8.2.5 小结小结8.2.4 存储过程vPL/SQL块类型:v命名块:编译后保管在数据库中,可以被反复调用,运转速度较快。存储过程和函数是命名块 v匿名块:每次执行时都要进展编译,它不能被存储到数据库中,也不能在其他的PL/SQL块中调用 存储过程续v一、 存储过程
36、的优点 v二、 存储过程的用户接口 v三、 游标 存储过程续v存储过程:由PL/SQL语句书写的过程,经编译和优化后存储在数据库效力器中,运用时只需调用即可。 v一、存储过程的优点v1. 运转效率高v2. 降低了客户机和效力器之间的通讯量v 3. 方便实施企业规那么存储过程续v二、 存储过程的用户接口v1. 创建存储过程 v2. 执行存储过程 v3. 删除存储过程 二、 存储过程的用户接口v1. 创建存储过程:创建存储过程:vCREATE Procedure 过程名参数过程名参数1,参数参数2,. ASv;v过程名:数据库效力器合法的对象标识过程名:数据库效力器合法的对象标识v参数列表:用名字
37、来标识调用时给出的参数参数列表:用名字来标识调用时给出的参数值,必需指定值的数据类型。参数也可以定值,必需指定值的数据类型。参数也可以定义输入参数、输出参数或输入义输入参数、输出参数或输入/输出参数。默输出参数。默以为输入参数。以为输入参数。v过程体:是一个过程体:是一个。包括声明部。包括声明部分和可执行语句部分分和可执行语句部分 存储过程的用户接口续例11 利用存储过程来实现下面的运用: 从一个账户转指定数额的款项到另一个账户中。 CREATE PROCEDURE TRANSFER(inAccount INT, outAccount INT, amount FLOAT) AS DECLARE
38、 totalDeposit FLOAT; BEGIN /* 检查转出账户的余额 */ SELECT total INTO totalDeposit FROM ACCOUNT WHERE ACCOUNTNUM=outAccount; IF totalDeposit IS NULL THEN /* 账户不存在或账户中没有存款 */ ROLLBACK; RETURN; END IF; 存储过程的用户接口续 IF totalDeposit amount THEN /* 账户账户存款缺乏 */ ROLLBACK; RETURN;END IF; UPDATE account SET total=total
39、-amount WHERE ACCOUNTNUM=outAccount; /* 修正转出账户,减去转出额 */ UPDATE account SET total=total + amount WHERE ACCOUNTNUM=inAccount; /* 修正转入账户,添加转出额 */COMMIT; /* 提交转账事务 */END;存储过程的用户接口续v重命名存储过程v ALTER Procedure 过程名1 RENAME TO 过程名2;存储过程的用户接口续v2. 执行存储过程执行存储过程v CALL/PERFORM Procedure 过程名过程名(参参数数1,参数,参数2,.);v运用运用CALL或者或者PERFORM等方式激活存储过等方式激活存储过程的执行。程的执行。v在在PL/SQL中,数据库效力器支持在过程体中中,数据库效力器支持在过程体中调用其他存储过程调用其他存储过程v例例12从账户从账户01003815868转一万
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 木材加工企业的信息化建设与管理考核试卷
- 化工产品批发商销售团队激励与培训实践考核试卷
- 冷冻饮品行业企业发展战略与实施路径考核试卷
- 半导体照明器件的振动测试考核试卷
- 家具品牌形象塑造考核试卷
- 机床附件的行业竞争格局与市场定位考核试卷
- 国际贸易中的社会责任与合规性考核试卷
- 成人高考物理电磁学综合应用考核试卷
- 小学生师生互动课件
- 耗材供应合同范本
- 剪纸艺术-认识剪纸
- 驾驶员违规违章学习记录表
- PID烙铁恒温控制器设计与制作_图文
- wincc全套脚本总结
- 简易瞬态工况法1
- 中国铁路总公司环境保护管理办法(铁总计统〔2015〕260号)
- 医疗器械全生命周期风险管理
- 技术分析介绍教程课件
- 环境与健康第六讲居室环境与健康
- 国家计委、建设部计价格[2002]10号工程勘察设计收费管理规定
- 故事小羊过桥PPT课件
评论
0/150
提交评论