数据库设计实验.ppt
交易员的操作,根据 顾客号、供应商号和商品号 完成交易:功能名称:交易员操作参数:providerID,customerId,partID 功能:根据协议书完成交易,将 交易员的操作封装为存储过程,根据 顾客号、供应商号和商品号 完成交易:存储过程名称:PASS_AGREEMENT参数:providerID,customerId,partID 功能:根据协议书完成交易,交易员操作功能,完成从Agreementt的一个元组到Business的一个元组的转化工作。这里考虑到了删除空的Suppiy和OfferTOBUY项,更加重要的是,这里考虑到了非法的Agreement的情况,在一段时间后,由于供应商或者顾客修改数据,Agreement可能就非法,这时就需要把这个事务废除,所以,这里检查了Supply表和OfferToBuy表中的数据,确保数据仍然正确。另外交易员,或者说交易所必须承担的一项任务是更新商品列表。这里在考虑顾客和供应商的时候并没有给予他们修改商品列表的权利,所以他们必须根据数据库中已有的项更新自己的供求信息。,存储过程设计,数据库系统中很重要的一个概念就是存储过程,合理的使用存储过程,可以有效的提高程序的性能;并且将商业逻辑封装在数据库系统中的存储过程中,可以大大提高整个软件系统的可维护性,当你的商业逻辑发生了改变的时候,不再需要修改并编译客户端应用程序以及重新分发他们到为数众多的用户手中,你只需要修改位于服务器端的实现相应商业逻辑的存储过程即可。在数据库的开发过程中,经常会遇到复杂的业务逻辑和对数据库的操作,这个时候就会用存储过程来封装数据库操作。如果项目的存储过程较多,书写又没有一定的规范,将会影响以后的系统维护困难和大SP逻辑的难以理解。另外如果数据库的数据量大或者项目对SP的性能要求很高,就会遇到优化的问题,否则速度有可能很慢。一个经过优化过的SP要比一个性能差的SP的效率甚至高几百倍。,一、什么是存储过程,存储过程是利用SQL Server所提供的Tranact-SQL语言所编写的程序。Tranact-SQL语言是SQL Server提供专为设计数据库应用程序的语言,它是应用程序和SQL Server数据库间的主要程序式设计界面。它好比Oracle数据库系统中的Pro-SQL和Informix的数据库系统能够中的Informix-4GL语言一样。这类语言主要提供以下功能,让用户可以设计出符合引用需求的程序:1)、变量说明2)、ANSI兼容的SQL命令(如Select,Update.)3)、一般流程控制命令(ifelse、while.)4)、内部函数,二、存储过程的书写格,CREATE PROCEDURE 拥有者.存储过程名;程序编号(参数#1,参数#1024)WITHRECOMPILE|ENCRYPTION|RECOMPILE,ENCRYPTIONFOR REPLICATIONAS 程序行其中存储过程名不能超过128个字。每个存储过程中最多设定1024个参数(SQL Server 7.0以上版本),参数的使用方法如下:参数名 数据类型 VARYING=内定值 OUTPUT每个参数名前要有一个“”符号,每一个存储过程的参数仅为该程序内部使用,参数的类型除了IMAGE外,其他SQL Server所支持的数据类型都可使用。=内定值相当于我们在建立数据库时设定一个字段的默认值,这里是为这个参数设定默认值。OUTPUT是用来指定该参数是既有输入又有输出值的,也就是在调用了这个存储过程时,如果所指定的参数值是我们需要输入的参数,同时也需要在结果中输出的,则该项必须为OUTPUT,而如果只是做输出参数用,可以用CURSOR,同时在使用该参数时,必须指定VARYING和OUTPUT这两个语句,例子:CREATE PROCEDURE order_tot_amt o_id int,p_tot int output ASSELECT p_tot=sum(Unitprice*Quantity)FROM orderdetailsWHERE ordered=o_id例子说明:该例子是建立一个简单的存储过程order_tot_amt,这个存储过程根据用户输入的定单ID号码(o_id),由定单明细表(orderdetails)中计算该定单销售总额单价(Unitprice)*数量(Quantity),这一金额通过p_tot这一参数输出给调用这一存储过程的程序,交易操作的数据完整性,与上述其他操作相比,对交易的操作对数据完整性要求比较高,其中需要注意的地方是;要防止同一用户(供应商,顾客)的数据因两个交易而同时修改;需要同时对供应数据库(Supply)、需求数据库(OfferToBuy)、交易数据库(Business)和协议数据库(Agreement)作出修改,而且需要保持这些修改的原子性;很显然,这些要求正是对于一个事务(transaction)的要求,所以可以用一个事务来完成签发一个协议的操作。,事务简介,事务是作为单个逻辑工作单元执行的一系列操作。一个逻辑工作单元必须有四个属性,称为ACID(原子性、一致性、隔离性和持久性)属性,只有这样才能成为一个事务,事务的属性(ACID),原子性(Atomicity)事务必须是原子工作单元;对于其数据修改,要么全都执行,要么全都不执行。一致性(Consistency)事务在完成时,必须使所有的数据都保持一致状态隔离性(Isolation)由并发事务所作的修改必须与任何其它并发事务所作的修改隔离持久性(Durability)事务完成之后,它对于系统的影响是永久性的。,执行事务的3种模式,1.显式事务:可以显式地在其中定义事务的启动和结束。BEGIN TRANSACTION标记一个显式本地事务起始点。BEGIN TRANSACTION将 TRANCOUNT 加 1语法BEGIN TRAN SACTION transaction_name|tran_name_variable WITH MARK description 参数 transaction_name是给事务分配的名称。不允许标识符多于 32 个字符。tran_name_variable用 char、varchar、nchar 或 nvarchar 数据类型声明有效事务的变量的名称WITH MARK description指定在日志中标记事务。Description 是描述该标记的字符串。如果使用了 WITH MARK,则必须指定事务名。WITH MARK 允许将事务日志还原到命名标记。,显式事务语句,