文档介绍:该【数据库设计实验 】是由【utuhlwwue61571】上传分享,文档一共【12】页,该文档可以免费在线阅读,需要了解更多关于【数据库设计实验 】的内容,可以使用淘豆网的站内搜索功能,选择自己适合的文档,以下文字是截取该文章内的部分文字,如需要获得完整电子版,请下载此文档到您的设备,方便您编辑和打印。根据 顾客号、供应商号和商品号 完成交易:
01
功能名称:交易员操作
02
参数: providerID , customerId , partID
03
功能:根据协议书完成交易
04
交易员的操作
03
参数:providerID , customerId , partID
02
存储过程名称: PASS_AGREEMENT
01
根据 顾客号、供应商号和商品号 完成交易:
04
功能:根据协议书完成交易
将 交易员的操作封装为存储过程
完成从Agreementt的一个元组到Business的一个元组的转化工作。这里考虑到了删除空的Suppiy和OfferTOBUY项,更加重要的是,这里考虑到了非法的Agreement的情况,在一段时间后,由于供应商或者顾客修改数据,Agreement可能就非法,这时就需要把这个事务废除,所以,这里检查了Supply表和OfferToBuy表中的数据,确保数据仍然正确。
另外交易员,或者说交易所必须承担的一项任务是更新商品列表。这里在考虑顾客和供应商的时候并没有给予他们修改商品列表的权利,所以他们必须根据数据库中已有的项更新自己的供求信息。
交易员操作功能
MS SQL Server数据库系统中很重要的一个概念就是存储过程,合理的使用存储过程,可以有效的提高程序的性能;并且将商业逻辑封装在数据库系统中的存储过程中,可以大大提高整个软件系统的可维护性,当你的商业逻辑发生了改变的时候,不再需要修改并编译客户端应用程序以及重新分发他们到为数众多的用户手中,你只需要修改位于服务器端的实现相应商业逻辑的存储过程即可。
在数据库的开发过程中,经常会遇到复杂的业务逻辑和对数据库的操作,这个时候就会用存储过程来封装数据库操作。如果项目的存储过程较多,书写又没有一定的规范,将会影响以后的系统维护困难和大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)、一般流程控制命令(if…else…、while….)4)、内部函数
二、存储过程的书写格
CREATE PROCEDURE [拥有者.]存储过程名[;程序编号][(参数#1,…参数#1024)][WITH{RECOMPILE | ENCRYPTION | RECOMPILE, ENCRYPTION}][FOR REPLICATION]AS 程序行其中存储过程名不能超过128个字。每个存储过程中最多设定1024个参数(SQL Server ),参数的使用方法如下:@参数名 数据类型 [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这一参数输出给调用这一存储过程的程序
例子说明:
01
与上述其他操作相比,对交易的操作对数据完整性要求比较高,其中需要注意的地方是;
05
很显然,这些要求正是对于一个事务(transaction)的要求,所以可以用一个事务来完成签发一个协议的操作。
03
需要同时对供应数据库(Supply)、需求数据库(OfferToBuy)、交易数据库(Business)
02
要防止同一用户(供应商,顾客)的数据因两个交易而同时修改;
04
和协议数据库(Agreement)作出修改,而且需要保持这些修改的原子性;
交易操作的数据完整性
事务是作为单个逻辑工作单元执行的一系列操作。
01
一个逻辑工作单元必须有四个属性,称为
02
ACID(原子性、一致性、隔离性和持久性)
03
属性,只有这样才能成为一个事务
04
事务简介
原子性(Atomicity)
事务必须是原子工作单元;对于其数据修改,要么全都执行,要么全都不执行。
一致性(Consistency)
事务在完成时,必须使所有的数据都保持一致状态
隔离性(Isolation)
由并发事务所作的修改必须与任何其它并发事务所作的修改隔离
持久性(Durability)
事务完成之后,它对于系统的影响是永久性的。
事务的属性(ACID)