图书管理系统数据库设计报告实例_第1页
图书管理系统数据库设计报告实例_第2页
图书管理系统数据库设计报告实例_第3页
图书管理系统数据库设计报告实例_第4页
图书管理系统数据库设计报告实例_第5页
已阅读5页,还剩27页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、1 / 32 文档可自由编辑打印图书管理系统 数据库设计报告文件标识:LMS-DATABASE当前版本:1.0作 者:XXX文件状态: 草稿 正式发布 正在修改完成日期:2011-12-242 / 32 文档可自由编辑打印版 本 历 史版本/状态作者参与者起止日期备注3 / 32 文档可自由编辑打印 目目目 录录录 0. 文档介绍文档介绍 .40.1 文档目的.40.2 文档范围.40.3 读者对象.40.4 参考文献.40.5 术语与缩写解释.41. 数据库环境说明数据库环境说明 .42. 数据库的命名规则数据库的命名规则 .53.概念设计概念设计 .64. 逻辑设计逻辑设计 .65.物理模

2、型物理模型 .85.0 表汇总.85.1 表 USERS.95.2 表 USERROLE.95.3 表 USERRIGHTS.105.4 表 OVERLIMITRECORD.105.5 表 LOSTRECORD.105.6 表 ORDERRECORD.115.7 表 BORROWRECORD.115.8 表 BOOK.115.9 表 LIABRARY.125.10 表 BOOKCATEGORY.125.11 表 BOOKKIND.135.12 表 SYSTEMLOG.136. 安全性设计安全性设计 .136.1 防止用户直接操作数据库的方法.136.2 用户帐号密码的加密方法.146.3 角色

3、与权限.147. 优化优化 .148. 数据库管理与维护说明数据库管理与维护说明 .158.1 数据库日常检查 .158.2 数据库备份方案.159. 数据库对象.164 / 32 文档可自由编辑打印0. 文档介绍文档介绍0.1 文档目的文档目的 本文档为图书管理系统的数据库设计文档,主要介绍系统的数据库设计,给出了系统的逻辑设计和物理设计,同时给出了数据库环境的说明,确定了数据库命名规则,给出了数据库的优化方案、安全性设计方案和数据库维护、管理等内容,本文档可作为项目开发人员在数据库实现时的参考和规范。0.2 文档范围文档范围本文档适用于项目开发的设计阶段,在项目开发阶段可按照本文档检验数据

4、库的实施情况。0.3 读者对象读者对象1.图书管理系统的开发人员 2.指导老师3.图书管理系统的测试人员4.图书管理系统的客户0.4 参考文献参考文献【01】王珊 萨师煊, 数据库系统概论 ,高等教育出版社,2006-05-040.5 术语与缩写解释术语与缩写解释缩写、术语缩写、术语解解 释释SPP精简并行过程,Simplified Parallel ProcessSD系统设计,System Design逻辑设计 把一种计划、规划、设想通过视觉的形式通过概念、判断、推理、论证来理解和区分客观世界的思维传达出来的活动过程 物理设计设计数据库的物理结构,根据数据库的逻辑结构来选定 RDBMS,并设

5、计和实施数据库的存储结构、存取方式等。 1. 数据库环境说明数据库环境说明 数据库系统:MySQL 数据库设计工具:Power Designer5 / 32 文档可自由编辑打印编程工具:Power Designer详细配置:2. 数据库的命名规则数据库的命名规则 2.1 数据库涉及字符规则数据库涉及字符规则采用 26 个英文字母(区分大小写)和 0 9 这十个自然数,加上下划线_组成,共 63个字符。不能出现其他字符(注释除外) 。 2.2 数据库对象命名规则数据库对象命名规则数据库对象包括表、视图(查询) 、存储过程(参数查询) 、函数、约束。对象名字由前缀和实际名字组成,长度不超过 30。

6、前缀:使用小写字母。如:表tb视图vi存储过程sp函数fn实际名字实际名字尽量描述实体的内容,由单词或单词组合,每个单词的首字母大写,其他字母小写,不以数字和_开头。因此,合法的对象名字类似如下。表tbUser_Info、tbMessage_Detail视图vi_MessageList存储过程sp_MessageAdd 2.3 数据库表命名规则数据库表命名规则字段由前缀和实际名字组成。实际名字中首单词一个系统尽量采取同一单词。前缀:使用小写字母 tb,表示表。例如:tbMember tbMember_Info t bForum_Board tbForum_Thread1 2.4 字段命名规则字

7、段命名规则数字、字符、日期/时间、lob(大对象)、杂项,字段由表的简称、下划线,实际名字加后缀组成。后缀:使用小写字母,代表该字段的属性。 例如: User_Idint User_Namestr User_RegDatedtm 2.5 视图命名规则视图命名规则字段由前缀和实际名字组成,中间用下划线连接。前缀:使用小写字母 vi,表示视图。例如:vi_User vi_UserInfo2.6 存储过程命名规则存储过程命名规则字段由前缀和实际名字组成,中间用下划线连接。前缀:使用小写字母 sp,表示存储过程。例如:sp_User2.7 SQL 语句规则语句规则6 / 32 文档可自由编辑打印所有

8、SQL 语句的关键词全部大写或首字母大写,比如 SELECT,UPDATE,FROM,ORDER,BY 等。3.概念设计概念设计4. 逻辑设计逻辑设计7 / 32 文档可自由编辑打印8 / 32 文档可自由编辑打印5.物理模型物理模型5.0 表汇总表汇总表名功能说明Users记录用户的基本信息,包括姓名、性别、单位、联系方式等UserRole记录用户的角色,不同的角色拥有不同的权限UserRights记录图书管理系统中用户可拥有的所有权限OverLimitRecord记录超期的图书借阅记录LostRecord记录图书遗失的记录OrderRecord记录读者预约图书的情况BorrowRecord

9、记录读者借阅图书的情况Book记录图书的基本信息,包括书名、出版社、页数、是否可借阅等Library记录图书馆分馆的基本情况,包括分馆地址、电话等信息9 / 32 文档可自由编辑打印BookCategory记录图书的类别及相关属性,划分不同类别可方便用户借阅查找BookKinds记录图书的种类及相关属性,不同种类的书籍有不同的赔付价格SystemLog记录系统的运行情况5.1 表表 Users表名Users列名数据类型空/非空约束条件表示含义UserIDInt 非空主键用户编号UserNamenvchar非空无用户姓名UserNumint非空无用户学号UserSexnvchar(2)可以为空只

10、能是男或是女用户性别UserRoleint非空只能为“用户角色”表中已有项的角色编号用户所属角色UserUnitnvchar可以为空无用户所在单位UserEmailnvchar可以为空格式为“”用户邮箱UserPhonenvchar(11)可以为空位数为 11 位,全部字符为数字用户联系电话UserPswnvchar(12)非空长度至少为 6,最多为 12 位的数字、字母的组合用户登录密码UserIsBorrowint非空无用户是否可借阅书籍UserBorroeCntint非空无用户当前可借阅的书籍数量补充说明1.UserRole 为外键,关联着用户角色表中的角色编号2.UserIsBorro

11、w 的初始值为 1,当 UserBorrowCnt 的值为 0 时其值为 0,当用户出现超期事务未处理时,UserIsBorrow 的值为-1,出现遗失事务未处理时其值-2,当同时有UserBorrowCnt 为 0 和超期事务未处理时其值为-3,当同时有 UserBorrowCnt 为 0 和遗失事务未处理时其值为-4,当同时有遗失和超期事务未处理时其值为-5,只有当其值为 1时表示当前可借,否则当前不可借阅。5.2 表表 UserRole表名UserRole列名数据类型空/非空约束条件表示含义RoleIDint非空主键角色编号RoleNamenvchar非空最大为 256 个字符角色名称R

12、oleDescribenvchar可以为空无角色描述RoleBorrowCntint非空无可借阅书籍的最大数量10 / 32 文档可自由编辑打印RoleBorrowDaysint非空无可借阅书籍的最大天数RoleBorrowTimesint非空无可续借的次数RoleContinueDaysint 非空无续借一次可多借阅书籍的天数RoleRightsint非空只能为权限表中已有项的编号角色所拥有的权限补充说明RoleRights 为外键,关联着权限表中的权限编号5.3 表表 UserRights表名UserRights列名数据类型空/非空约束条件表示含义RightsIdint非空主键权限编号Ri

13、ghtsNamenvchar非空最大为 256 个字符权限名称RightsDescribenvchar可以为空无权限描述补充说明无5.4 表表 OverLimitRecord表名OverLimitRecord列名数据类型空/非空约束条件表示含义OLRIDint非空主键超期记录编号OLRUserIDint非空无超期借阅书籍的读者编号OLRBookIDint非空无超期被借阅的书籍编号OverDaysint非空无超期天数IsFineboolean非空无是否已经缴纳超期罚款的标识OverCostint非空无超期应缴纳的罚款金额补充说明OLRUserID 和 OLRBookID 为外键,分别关联用户表中

14、的用户编号和图书表中的图书编号5.5 表表 LostRecord表名LostRecord列名数据类型空/非空约束条件表示含义LostRecIDint非空主键书籍遗失记录编号LostRecBookIDint非空无遗失的书籍编号LostRecUserIDint非空无遗失书籍的用户编号LostRecDatedate非空无书籍遗失事务等级日期LostIsFineboolean非空无是否已经缴纳遗失书籍赔付款LostReBuyboolean非空无是否已经重新购入该书籍11 / 32 文档可自由编辑打印补充说明LostRecUserID 和 LostRecBookID 为外键,分别关联用户表中的用户编号和

15、图书表中的图书编号5.6 表表 OrderRecord表名OrderRecord列名数据类型空/非空约束条件表示含义OrderRecIDint非空主键预约图书记录的编号OrderRecBookIDint非空无被预约图书的编号OrderRecUserIDint非空无预约图书的用户编号OrderRecDatedate非空无预约图书的日期OrderIsFinishboolean非空无预约活动是否完成补充说明OrderRecUserID 和 OrderRecBookID 为外键,分别关联用户表中的用户编号和图书表中的图书编号5.7 表表 BorrowRecord表名OrderRecord列名数据类型空

16、/非空约束条件表示含义BRDint非空主键借阅书籍记录的编号BRUserIDint非空无借阅书籍的用户的编号BRBookIDint非空无被借阅的书籍的编号BRDatedate非空无借阅书籍的时间BRIsBackboolean非空无是否已经归还书籍的标识位BRBackDatedate非空无用户应该归还书籍的最大日期BRIsContinueboolean非空无用户是否可以续借书籍BRContinueTimesint非空无用户还可以续借该书籍的次数BRIsOVerLimitboolean非空无借阅的书籍是否已经超期BROverLimitFinevnchar可以为空无若书籍超期所应缴纳的超期款补充说明

17、OrderRecUserID 和 OrderRecBookID 为外键,分别关联用户表中的用户编号和图书表中的图书编号5.8 表表 Book表名Book列名数据类型空/非空约束条件表示含义BookIDint非空主键书籍编号BookNamenvchar非空最大长度为 256 个字符书籍名称BookAuthornvchar非空最大长度为 256 个字符书籍的作者名12 / 32 文档可自由编辑打印ISBNIDnvchar非空最大长度为 256 个字符书籍的 ISBN 码Publishnvchar非空最大长度为 256 个字符书籍的出版社名PublishPlacenvchar非空最大长度为 256

18、个字符书籍的出版地PublishDatedate非空无书籍的出版时间TotalWordsint非空无书籍的总字数TotalPageint非空无书籍的总页数BookPricenvchar非空无书籍的定价BookAbstructnvchar非空无书籍的内容简介BookCategoryint非空无书籍的类别BookInDatedate非空无书籍的入库时间BookLibraryint非空无书籍所在的图书分馆IsBorrowboolean非空无标识书籍当前是否可借BookKindint非空无书籍的种类补充说明1.BookCategory 为外键,关联着图书类别表中的类别编号2.BookKind 为外键,

19、关联着图书种类表中的种类编号3.图书类别表示图书的内容的类别,如哲学类,文学类,设置图书类别图书可以方便用户进行查找和定位,图书的种类表示书籍的种类,如新书、珍藏版书籍、外文书、中文书,设置图书种类是可能不同种类的书籍在超期、遗失时的赔付额度不一样,如 1980 年前的书属于珍藏版的书,遗失后应该按定价的 5 倍赔付等4.当书籍当前已经被借出或者已经遗失了,则该书籍当前不可借阅5.书籍作者的最大长度设为 256 是因为可能一本书的作者为多个,名字的总长度较大6.ISBN 码为图书的分类编码,同样的书籍的 ISBN 码应该一样5.9 表表 Liabrary表名Liabrary列名数据类型空/非空

20、约束条件表示含义LiabraryIDint非空主键图书分馆编号LibNamnvchar非空最大长度为 256 个字符图书分馆名称LibPhonenvchar非空最大长度为 11图书分馆的联系电话LibAddressnvchar非空最大长度为 256 个字符图书分馆的地址LibAbstructnvchar非空无图书分馆的简介补充说明一个图书管理系统可能同时管理位于不同位置的几个图书分馆,所以需要设置图书分馆表,一本图书也应该属于某一个图书分馆13 / 32 文档可自由编辑打印5.10 表表 BookCategory表名BookCategory列名数据类型空/非空约束条件表示含义CategoryI

21、Dint非空主键图书类别编号CategoryNamenvchar非空最大长度为 256 个字符图书类别名称CategoryDescribenvchar非空无类别的简介补充说明图书的类别是指图书内容的分类,如哲学类、历史类、计算机类等,将图书按类别归类可方便用户的查找和借阅5.11 表表 BookKind表名BookKind列名数据类型空/非空约束条件表示含义KindIDint非空主键图书种类编号KindNamenvchar非空最大长度为 256 个字符图书种类名称KindDescribenvchar可以为空无图书种类的简介OverLimitCostnvchar非空无图书超期的罚金额度LostC

22、ostnvchar非空无图书遗失的罚金额度补充说明图书可能会被划分为新书、珍藏版书籍、外文书、中文书等种类,根据种类的不同书籍的超期、遗失的赔付金额也不同,如外文书遗失需要赔付两倍定价的金额,而一般的中文书只需按定价赔付等,所以需要划分不同的书籍种类5.12 表表 SystemLog表名SystemLog列名数据类型空/非空约束条件表示含义LogIDint非空主键系统日志编号LogContentnvchar非空无系统日志内容LogTimedate&time非空无系统日志产生的时间IsSysRightboolean非空无系统是否正常补充说明系统日志记录可监测系统是运行是否正确,这对于维护

23、和恢复数据库是很重要的14 / 32 文档可自由编辑打印6. 安全性设计安全性设计6.1 防止用户直接操作数据库的方法防止用户直接操作数据库的方法1.用户权限控制给每个用户角色限制权限,不同的角色拥有不同的权限,用户只能行使自己权限范围内的权限,如普通用户只能查看自己的借阅记录不能任意修改,而管理员和超级管理员则可以修改用户的借阅记录,通过角色,权限等的一系列授予和回收操作可以有效的进行用户的权限控制,从而防止用户恶意操作、篡改数据库信息。2.数据库登录设密给数据库设置登录账号和密码,只有拥有直接访问数据库权限的用户在键入正确的账号和密码后才能通过软件登录到数据库进行操作,可防止用户恶意操作数

24、据库。3.限制操作系统存取权限 使用 Oracle 数据库系统是依存在操作系统之上的,如果操作系统被人侵入,那么通过修改配置文件等一系列方法,Oracle 数据库的安全性也将荡然无存,所以对于安全性高的数据库,可以通过限制操作系统的存取权限来提高数据库的安全性。 6.2 用户帐号密码的加密方法用户帐号密码的加密方法使用 MD5 加密方法对用户账号密码进行加密。MD5 方法采用单项加密的加密方法,即只能对数据进行加密,而不能对加密后的数据进行解密,这样经过 MD5 算法处理的账号和秘密存储在数据库中即使被人恶意获取到,也不可能知道密码的具体数据,即做到了对账号密码的更强的保护。6.3 角色与权限

25、角色与权限角色可以访问的表与列操作权限超级管理员所有表及列增删改查Users、UserRole、OverLimitRecord、LostRecord、BorrowRecord、Book、Library、BookCategory、BookKinds增删改查管理员UserRights、SystemLog查看Users查看、修改、删除、增加信息普通用户OverLimitRecord、LostRecord、BorrowRecord、Book、Library查看7. 优化优化优先级优化对象(目标)措施15 / 32 文档可自由编辑打印高数据库索引根据查询条件,建立索引,优化索引、优化访问方式,限制结果集

26、的数据量高数据库碎片定期整理数据库产生的碎片,提高数据库的性能高数据库缓存优化数据库缓存方案高数据库对象优化数据库对象的放置策略,尽量让数据库对象均匀地把数据分布在系统的磁盘中,平衡 I/O 访问,避免 I/O 瓶颈。 8. 数据库管理与维护说明数据库管理与维护说明8.1 数据库日常检查数据库日常检查1.检查数据库状态:确认数据库是否在 open 状态,正常提供服务。 SQL select status, instance_role from v$instance;2.数据库版本检查:数据库应该打了最新的 patchset。 SQLselect * from v$version;3.查看 SG

27、A 区域:SGA 区各项 buffer 之和应该小于系统物理内存的一半。 SQLshow sga;4.回滚段竞争检查:如果是 oracle8i 版本返回值应该低于 2%。如果该值过高,8i 需要手工建立更多的回滚段,如果是 9i,返回值应该为 0,如果持续存在非零值,应该增加回滚表空间的大小。 8i: SQL select The average of waits/gets is |round(sum(waits) / sum(gets) * 100,2)|%From v$rollstat; 9i: SQLselect distinct nospaceerrcnt as nospace Fro

28、m v$undostat Where begin_timesysdate-(1/12);5.查看日志文件:数据库运行时,可以通过查询 v$log_history 来观察 log switch 的切换时间。联机日志最好是业务非高峰期每小时切换一次,业务高峰期 20 分钟左右切换一次。SQLselect to_char(first_time,yyyy-mm-dd hh24:mi:ss) change_time from v$log_history;6.查看表空间:查看各个表空间所占的大小,剩余空间,使用空间百分比等信息,特别是当业务表空间的剩余空间低于 50M 或者使用空间百分比大于 90%时,需

29、要考虑增加表空间的大小。 SQL select a.tablespace_name,a.bytes totalbytes,sum(b.bytes) freebytes from dba_data_files a,dba_free_space b where a. = b. group by a.tablespace_name, a.bytes ; 7.检查 job 状态:Broken 列应该为 N;如果 Broken 列为 Y,检查 oracle 告警日志,分析 job失败的原因。解决后运行:exec dbms_job.run(:job); SQLselectjob,what,to_char(

30、next_date,yyyy/mm/ddhh24:mi:ss),broken,failures from dba_jobs; 8.查看数据库连接用户:查看当前数据库连接的用户进程的具体信息,包括连接的数据库用户名,机器名,运行的程序名,进程状态。 16 / 32 文档可自由编辑打印select username,machine,program,status from v$session where osuser oracle;8.2 数据库备份方案数据库备份方案添加任务计划,定期定时运行备份批处理命令,实现自动备份。设计一个物理备份和逻辑备份相结合的数据库备份方案,以保证数据的完整性和 0 损

31、失恢复。逻辑备份:星期一 完全备份 在 00:00 时备份 星期二 增量备份 在 00:00 时备份星期三 增量备份 在 00:00 时备份星期四 增量备份 在 00:00 时备份星期五 累积备份 在 00:00 时备份星期六 增量备份 在 00:00 时备份星期日 增量备份 在 00:00 时备份分析:每天在 00:00 时备份是因为在这个时段的访问量相对很少,星期一完全备份可以将数据库中的信息全部备份,而之后的几天采用增量备份可以减少备份量,加快备份速度。在在星期五选择累计备份,是考虑到数据库出错时恢复的考虑,当数据库在某一周有错误时,可以直接恢复到星期五的数据,而不用一天一天的按增量备份

32、的数据恢复。物理备份:9. 数据库对象数据库对象 序列序列序列名称序列名称Users_seq序列描述序列描述该序列用以完成用户编号的自增序列实现序列实现CREATE SEQUENCE Users_seqINCREMENT BY 1 START WITH 1 NOMAXvalueNOCYCLE NOCACHE;序列名称序列名称UserRole_seq序列描述序列描述创建序列,用以完成用户角色编号的自增序列实现序列实现CREATE SEQUENCE UserRole_seq备份方法备份频率备份时间备份目的备注本地热备1 次/天00:00保留最近一周的备份数据本地冷备1 次/一月每周星期五下午保留数

33、据库全部数据异地导出备份1 次/天12:00保留最近一周的备份数据17 / 32 文档可自由编辑打印INCREMENT BY 1 START WITH 1 NOMAXvalueNOCYCLE NOCACHE;序列名称序列名称UserRight_seq序列描述序列描述创建序列,用以完成用户权限编号的自增序列实现序列实现CREATE SEQUENCE UserRight_seqINCREMENT BY 1 START WITH 1 NOMAXvalueNOCYCLE NOCACHE;存储过程存储过程存储过程名称存储过程名称InsertToUsers存储过程描述存储过程描述向用户表中插入新的用户记录

34、的存储过程参数说明依次表示:用户姓名,学号、性别、所属角色编号、单位、邮箱和电话最后一个参数为插入结果的返回值,成功时返回 1,否则返回出错代码存储过程实现存储过程实现CREATE or REPLACE PROCEDURE InsertToUsers(ItemName in varchar,ItemNum in integer,ItemSex in varchar,ItemRole in integer,ItemUnit in varchar,ItemEmail in varchar,ItemTel in varchar,ItemPsw in varchar,ItemIsBorrow in i

35、nteger,ItemBorrowCnt in integer,InsertRes out integer)isBEGINSAVEPOINT SP1;INSERT INTO Users (UserID,UserName,UserNum,UserSex,UserRole,UserUnit,UserEmail,UserTel,UserPsw,UserIsBorrow,UserBorrowCnt )VALUES ( Users_seq, ItemName, ItemNum, ItemSex, ItemRole, ItemUnit, ItemEmail, ItemTel, ItemPsw,ItemIs

36、Borrow, ItemBorrowCnt );InsertRes := 1;18 / 32 文档可自由编辑打印 commit; EXCEPTIONwhen DUP_VAL_ON_INDEX then InsertRes := SQLCODE;When OTHERS then InsertRes := SQLCODE;ROLLBACK TO SAVEPOINT SP1;END;存储过程名称存储过程名称DelOnUsers存储过程描述存储过程描述删除用户表记录参数说明:依次表示:用户姓名、学号、性别、所属角色编号、单位、邮箱和电话、密码当不需要依据某一项来选择删除的用户时,如果为字符类型则传入N

37、ULL,如果为数字类型则传入-1 如删除编号为 1 的用户时调用函数为DelOnUsers(1,NULL,-1,NULL,-1,NULL,NULL,NULL);最后一个参数为删除记录的执行结果成功时返回 1 否则返回出错代码存储过程实现存储过程实现CREATE or REPLACE PROCEDURE DelOnUsers(ItemID in integer,ItemName in varchar,ItemNum in integer,ItemSex in varchar,ItemRole in integer,ItemUnit in varchar,ItemEmail in varchar,

38、ItemTel in varchar,ItemPsw in varchar,ItemIsBorrow in integer,ItemBorrowCnt in integer,DelRes out integer)istmpCondition varchar(500);BEGIN SAVEPOINT SP1;tmpCondition := NULL;-如果需要根据用户的编号删除,则只需获取用户的编号,而不用再看用户的其他属性,因为用户编号是唯一IF ItemID -1 THENtmpCondition := tmpCondition | ItemID;19 / 32 文档可自由编辑打印-如果是根

39、据用户的其他属性删除时ELSEIF ItemName IS NOT NULL THENtmpCondition := tmpCondition |UserName = |ItemName;END IF;IF ItemNum -1 THEN IF tmpCondition IS NOT NULL THEN tmpCondition := tmpCondition | UserNum = |ItemNum; ELSE tmpCondition := tmpCondition | ADD UserNum = |ItemNum; END IF;END IF;IF ItemSex IS NOT NULL

40、 THEN IF tmpCondition IS NOT NULL THEN tmpCondition := tmpCondition | UserSex = |ItemSex; ELSE tmpCondition := tmpCondition | ADD UserSex = |ItemSex; END IF;END IF;IF ItemRole -1 THEN IF tmpCondition IS NOT NULL THEN tmpCondition := tmpCondition | UserRole = |ItemRole; ELSE tmpCondition := tmpCondit

41、ion | ADD UserRole = |ItemRole; END IF;END IF;IF ItemUnit IS NOT NULL THEN IF tmpCondition IS NOT NULL THEN tmpCondition := tmpCondition | UserUnit = |ItemUnit; ELSE tmpCondition := tmpCondition | ADD UserUnit = |ItemUnit; END IF;END IF;IF ItemEmail IS NOT NULL THEN IF tmpCondition IS NOT NULL THEN

42、tmpCondition := tmpCondition | UserEmail = |ItemEmail; ELSE tmpCondition := tmpCondition | ADD UserEmail = |ItemEmail; END IF;20 / 32 文档可自由编辑打印END IF;IF ItemTel IS NOT NULL THEN IF tmpCondition IS NOT NULL THEN tmpCondition := tmpCondition | UserTel = |ItemTel; ELSE tmpCondition := tmpCondition | AD

43、D UserTel = |ItemTel; END IF;END IF;IF ItemPsw IS NOT NULL THEN IF tmpCondition IS NOT NULL THEN tmpCondition := tmpCondition | UserPsw = |ItemPsw; ELSE tmpCondition := tmpCondition | ADD UserPsw = |ItemPsw; END IF;END IF;IF ItemPsw -1 THEN IF tmpCondition IS NOT NULL THEN tmpCondition := tmpConditi

44、on | UserIsBorrow = |ItemIsBorrow; ELSE tmpCondition := tmpCondition | ADD UserIsBorrow = |ItemIsBorrow; END IF;END IF;IF ItemPsw -1 THEN IF tmpCondition IS NOT NULL THEN tmpCondition := tmpCondition | UserBorrowCnt = |ItemBorrowCnt; ELSEtmpCondition := tmpCondition | ADD UserBorrowCnt = |ItemBorrow

45、Cnt; END IF; END IF;END IF;-执行删除语句tmpCondition := DELETE FROM Users WHERE |tmpCondition;execute immediate tmpCondition;DelRes := 1;commit;EXCEPTION When NO_DATA_FOUND then DelRes := SQLERRM; When OTHERS then21 / 32 文档可自由编辑打印 DelRes := SQLERRM; ROLLBACK TO SAVEPOINT SP1;END;存储过程名称存储过程名称UpdateOnUsers存

46、储过程描述存储过程描述更新记录项的存储过程参数说明参数一:需要更新的记录的查找条件,数组记录一次对应用户姓名、学号、性别、所属角色编号、单位、邮箱和电话、密码如果不需要某一项作为查找条件时,该项对应位置传入 NULL参数二:记录需要更新的数据项,数组记录依次对应用户姓名、学号、性别、所属角色编号、单位、邮箱和电话、密码如果不需要更新某一项的值时,该项对应位置传入 NULL最后一个参数为更新结果的返回值,成功时返回 1,否则返回出错代码存储过程实现存储过程实现-创建一个数组类型,用以存储需要修改的记录的值CREATE or replace TYPE Users_Arr AS varray(11)

47、 of varchar2(500);CREATE or REPLACE PROCEDURE UpdateOnUsers(ConditionArr in Users_Arr,ValueArr in Users_Arr,UpdateRes out integer)IStmpCondition varchar(500);tmpValue varchar(500);BEGINSAVEPOINT SP1;tmpCondition := NULL;tmpValue := NULL;IF ConditionArr(0) IS NOT NULL THENtmpCondition := tmpCondition

48、| UserID = |ConditionArr(0);END IF;IF ValueArr(0) IS NOT NULL THENtmpValue := tmpValue| UserID = |ValueArr(0);END IF;IF ConditionArr(1) IS NOT NULL THENIF tmpCondition IS NOT NULL THENtmpCondition := tmpCondition| UserName = |ConditionArr(1);ELSEtmpCondition := tmpCondition| AND UserName = |Conditio

49、nArr(1);END IF;END IF;IF ValueArr(1) IS NOT NULL THEN22 / 32 文档可自由编辑打印IF tmpValue IS NOT NULL THENtmpValue := tmpValue| UserName = |ValueArr(1);ELSEtmpValue := tmpValue|, UserName = |ValueArr(1);END IF;END IF;IF ConditionArr(2) IS NOT NULL THENIF tmpCondition IS NOT NULL THENtmpCondition := tmpCondi

50、tion| UserNum = |ConditionArr(2);ELSEtmpCondition := tmpCondition| AND UserNum = |ConditionArr(2);END IF;END IF;IF ValueArr(2) IS NOT NULL THENIF tmpValue IS NOT NULL THEN tmpValue := tmpValue| UserNum = |ValueArr(2);ELSEtmpValue := tmpValue|, UserNum = |ValueArr(2);END IF;END IF;IF ConditionArr(3)

51、IS NOT NULL THENIF tmpCondition IS NOT NULL THENtmpCondition := tmpCondition| UserSex = |ConditionArr(3);ELSEtmpCondition := tmpCondition| AND UserSex = |ConditionArr(3);END IF;END IF;IF ValueArr(3) IS NOT NULL THENIF tmpValue IS NOT NULL THENtmpValue := tmpValue| UserRole = |ValueArr(3);ELSEtmpValu

52、e := tmpValue|, UserRole = |ValueArr(3);END IF;END IF;IF ConditionArr(4) IS NOT NULL THENIF tmpCondition IS NOT NULL THENtmpCondition := tmpCondition| UserRole = |ConditionArr(4);ELSEtmpCondition := tmpCondition| AND UserRole = |ConditionArr(4);23 / 32 文档可自由编辑打印 END IF;END IF;IF ValueArr(4) IS NOT N

53、ULL THENIF tmpValue IS NOT NULL THENtmpValue := tmpValue| UserRole = |ValueArr(4);ELSEtmpValue := tmpValue|, UserRole = |ValueArr(4);END IF;END IF;IF ConditionArr(5) IS NOT NULL THENIF tmpCondition IS NOT NULL THENtmpCondition := tmpCondition| UserUnit = |ConditionArr(5);ELSEtmpCondition := tmpCondi

54、tion| AND UserUnit = |ConditionArr(5);END IF;END IF;IF ValueArr(5) IS NOT NULL THENIF tmpValue IS NOT NULL THENtmpValue := tmpValue| UserUnit = |ValueArr(5);ELSEtmpValue := tmpValue|, UserUnit = |ValueArr(5);END IF;END IF;IF ConditionArr(6) IS NOT NULL THENIF tmpCondition IS NOT NULL THENtmpConditio

55、n := tmpCondition| UserEmail = |ConditionArr(6);ELSEtmpCondition := tmpCondition| AND UserEmail = |ConditionArr(6);END IF;END IF;IF ValueArr(6) IS NOT NULL THENIF tmpValue IS NOT NULL THENtmpValue := tmpValue| UserEmail = |ValueArr(6);ELSEtmpValue := tmpValue|, UserEmail = |ValueArr(6);END IF;END IF

56、;IF ConditionArr(7) IS NOT NULL THENIF tmpCondition IS NOT NULL THEN24 / 32 文档可自由编辑打印tmpCondition := tmpCondition| UserTel = |ConditionArr(7);ELSEtmpCondition := tmpCondition| AND UserTel = |ConditionArr(7);END IF;END IF;IF ValueArr(7) IS NOT NULL THENIF tmpValue IS NOT NULL THENtmpValue := tmpValue

57、| UserTel = |ValueArr(7);ELSEtmpValue := tmpValue|, UserTel = |ValueArr(7);END IF;END IF;IF ConditionArr(8) IS NOT NULL THENIF tmpCondition IS NOT NULL THENtmpCondition := tmpCondition| UserPsw = |ConditionArr(8);ELSEtmpCondition := tmpCondition| AND UserPsw = |ConditionArr(8);END IF;END IF;IF Value

58、Arr(8) IS NOT NULL THENIF tmpValue IS NOT NULL THENtmpValue := tmpValue| UserPsw = |ValueArr(8);ELSEtmpValue := tmpValue|, UserPsw = |ValueArr(8);END IF;END IF;IF ConditionArr(9) IS NOT NULL THENIF tmpCondition IS NOT NULL THENtmpCondition := tmpCondition| UserIsBorrow = |ConditionArr(9);ELSE tmpCon

59、dition := tmpCondition| AND UserIsBorrow = |ConditionArr(9);END IF;END IF;IF ValueArr(9) IS NOT NULL THENIF tmpValue IS NOT NULL THEN tmpValue := tmpValue| UserIsBorrow = |ValueArr(9);ELSEtmpValue := tmpValue|, UserIsBorrow = |ValueArr(9);END IF;25 / 32 文档可自由编辑打印END IF;IF ConditionArr(10) IS NOT NUL

60、L THENIF tmpCondition IS NOT NULL THENtmpCondition := tmpCondition| UserBorrowCnt = |ConditionArr(10);ELSEtmpCondition := tmpCondition| AND UserBorrowCnt = |ConditionArr(10);END IF;END IF;IF ValueArr(10) IS NOT NULL THENIF tmpValue IS NOT NULL THENtmpValue := tmpValue| UserBorrowCnt = |ValueArr(10);ELSE

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论