图书馆管理系统数据库资料
- 格式:doc
- 大小:1.34 MB
- 文档页数:10
6、你所在的学校将开发图书管理信息系统,请对该系统进行分析:(1)画出数据流图。
“图书馆管理信息系统”的顶层数据流图“图书馆管理信息系统”l层数据流图加工2“图书管理”的数据流图加工3“读者管理”数据流图加工4“借阅管理”数据流图(2)编写数据字典。
参考答案:1)数据流条目数据流名称:图书录入信息简述:图书采编信息数据流来源:图书购买后,由图书馆管理人员编码整理后,输入计算机数据流去向:加工2.1图书信息管理,该加工将录入的数据存入数据库(图书信息表)数据项组成:图书ID+图书类别+书名+作者+译者+出版社+单价+出版日期+购买数量数据流量: 0本/天高峰流量:500本/天数据流名称:图书查询信息简述:图书查询信息数据流来源:读者数据流去向:加工2.1,图书信息管理数据项组成:图书编码|书名|作者|出版社数据流量:2000次/天高峰流量:4000次/天数据流名称:查询情况简述:返回给读者的查询结果数据流来源:加工2.1图书信息管理数据流去向:读者数据项组成:查无此书|符合条件的图书数量+{图书馆藏号+图书类别+书名+作者+出版社+出版日期+在库册数}数据流量:2000次/天高峰流量:4000次/天数据流名称:读者录入信息简述:读者信息数据流来源:图书管理员数据流去向:加工3.2读者信息管理,该加工将录入的数据存入数据库(读者信息表)数据项组成:读者ID+读者编号+读者姓名+读者性别+出生日期+办证日期+读者状态+已借书数+证件名称+证件号码+读者单位+读者部门+联系电话+联系地址+电子邮件+备注数据流量: 0人次/天高峰流量:500人次/天2)加工条目加工名:读者信息管理处理逻辑编号:3.2处理逻辑:接收读者信息的录入,并检查有无错误,如果没有错误,将数据存入读者信息表激发条件:接收到读者信息时输入:读者录入信息输出:读者信息加工名:还书管理编号:4.2处理逻辑:在借阅信息表查找应还日期IF 当日期日期超过应还日期或图书丢失 THEN 发“罚款信息”ELSE 将还书信息存入还书信息表激发条件:接收到读者借书证时输入:还书信息输出:罚款信息3)数据存储条目数据存储编号:D1数据存储名称:读者信息表简述:存储读者详细信息组成:读者ID+读者编号+读者姓名+读者性别+出生日期+办证日期+读者状态+已借书数+证件名称+证件号码+读者单位+读者部门+联系电话+联系地址+电子邮件+备注关键字:读者ID组织方式:索引文件,以读者ID为关键字相关连的处理:加工3.2、加工4.1、加工4.2数据存储编号:D2数据存储名称:图书信息表简述:存储图书详细信息组成:图书编号+图书名称+标准ISBN+类别编号+类别名称+书架位置+作者+译者+出版社名+出版地点+图书页数+图书价格+现存量+库存总量+借阅次数+是否注销+入库日期+出版日期+内容简介+备注关键字:图书编号组织方式:索引文件,以图书编号为关键字相关连的处理:加工2.1、加工4.1数据存储编号:D3数据存储名称:借阅信息表简述:存储借书情况的详细信息组成:图书编号+图书名称+读者编号+读者姓名+借阅数量+借阅日期+应还日期+续借次数关键字:无组织方式:普通文件相关连的处理:加工4.1、加工4.24)数据项条目数据项名称:读者编号别名:证号简述:给每个读者的一个唯一的、做标识用的号码组成:单位代码+流水号码类型:字符串长度:6位取值范围:000000..999999数据项名称:办证日期简述:给读者签发借书证的日期组成:年+月类型:字符串长度:6位取值范围:有意义的年、月值数据项名称:读者类别简述:读者在图书流通管理中的身份和借出权限的类型组成:[教师|行政人员|学生]类型:1个字符长度:1位取值范围:[0|1|2]。
图书馆管理系统数据库设计1、系统简要分析1。
1图书资料基本管理(1)、新书编号、登记、入库:将新购入的书籍按照国家统一的分类编号;登记书号、书名、作者、出版社等基本信息,将新购图书入库.(2)、检索查询:按照各种组合条件对书库图书进行查询,也可以进行模糊查询.(3)、图书资料统计:根据要求对图书总数、各类图书数以及图书单价合计统计,打印日常报表。
(4)、旧书出库处理:通过查询确定过期期刊杂志、旧书籍以及由于丢失等其他原因需要从书库中撤销的图书资料,并从书库中撤除。
1.2图书资料借阅管理(1)、借还书管理:主要负责日常的借书登记、还书登记,和逾期未还图书的催还工作。
(2)、检索查询:按照各种组合条件对图书借阅情况查询,也可以进行模糊查询。
(3)、借书统计:统计各类书借阅情况,借阅次数;统计个人借书情况,打印日常报表。
(4)、定期整理图书借阅信息:将还书情况总结整理后彻底删除。
此外,图书管理人员还要定期做整理图书资料的全部图书清单、分类印图书清单、借阅清单以及整理填写各种报表等工作。
2、业务流程分析2。
1 借书业务流程2。
2 新书购进入库业务流程2。
3 还书业务流程2.4 销书业务流程3、数据流程图符号说明:实体处理逻辑数据流数据存储3. 1 系统的总数据流程图3。
2 借书处理数据流程图3。
3 还书处理数据流程图3.4 购书处理数据流程图4、数据字典4.1 数据项的描述数据项名:学号数据项含义说明:学生的唯一编号别名:数据类型:字符型长度:10取值范围:‘0000000000’-‘9999999999’取值说明:第1位为校区代码,2—3位为入学年份,.。
..与其他数据项的关系表4-1 数据项的定义表4-2 数据流的描述表4—3 处理逻辑的描述表4—4 数据存储的描述表4—5 外部实体的描述数据流编号:D1数据流名称:借书单简述:借阅者所要借的图书信息单数据流来源:借阅者数据流去向:借书处理模块数据流组成:图书编号+书名+借阅证号等数据流量:200张/天高峰流量:400张/天数据流编号:D2数据流名称:图书简述:借阅者从图书馆所借的图书数据流来源:借书处理模块数据流去向:借阅者数据流组成:图书编号+图书名+条形码号+出版社+出版日期+入库日期+作者+单价等数据流量:300本/天高峰流量:500本/天数据流编号:D3数据流名称:图书简述:借阅者要准备归还给图书馆的图书数据流来源:借阅者数据流去向:还书处理模块数据流组成:图书编号+图书名+条形码号+出版社+出版日期+入库日期+作者+单价等数据流量:300本/天高峰流量:500本/天数据流编号:D4数据流名称:不合格借书单简述:经借书处理模块验证不合格的借书单数据流来源:借书处理模块数据流去向:借阅者数据流组成:图书编号+书名+借阅证号等数据流量: 50张/天高峰流量:100张/天数据流编号:D5数据流名称:借书清单简述:经借书处理模块处理后的借书情况数据单数据流来源:借书处理模块数据流去向:图书库存情况存档数据流组成:图书编号+图书名+借阅日期+借阅证号+管理员编号等数据流量: 200张/天高峰流量:400张/天数据流编号:D6数据流名称:还书清单简述:还书信息清单数据流来源:还书处理模块数据流去向:图书库存情况存档数据流组成:图书编号+图书名+借阅证号+还书日期+管理员编号等数据流量:150本/天高峰流量:400本/天数据流编号:D7数据流名称:订书单简述:订购新书的信息单数据流来源:采购员数据流去向:购书处理模块数据流组成:图书名+图书数量+价格+采购员姓名+采购单位名称+图书出版社+出版日期等数据流量:1张/3个月高峰流量:1张/月数据流编号:D8数据流名称:购书清单简述:购买图书后的信息单数据流来源:购书处理模块数据流去向:管理员数据流组成:图书名+图书数量+价格+采购员姓名+采购员编号+出版社+出版日期+供货商名称+采购日期等数据流量:1张/3个月高峰流量:1张/月数据流编号:D9数据流名称:入库新书清单简述:准备入库图书信息单数据流来源:管理员数据流去向:新书入库处理模块数据流组成:图书编号+图书名+数量+管理人员编号+入库日期等数据流量:1张/3个月高峰流量:1张/月数据流编号: D10数据流名称:入库清单简述:刚新入库图书的信息单数据流来源:新书入库处理模块数据流去向:图书库存情况存档数据流组成:图书编号+图书名+数量+管理人员编号+入库日期等数据流量:1张/3个月高峰流量:1张/月数据流编号:D11数据流名称:销书计划简述:准备从书库中撤除一部分图书的计划数据流来源:管理员数据流去向:销书处理模块数据流组成:图书编号+图书名称+入库日期+管理员编号+日期+数量等数据流量:1张/6个月高峰流量:1张/月数据流编号:D12数据流名称:销书清单简述:通过销书处理刚从书库中撤除的图书信息单数据流来源:销书处理模块数据流去向:图书库存情况存档数据流组成:图书编号+图书名称+入库日期+管理员编号+出库日期+数量+总价等数据流量:1张/6个月高峰流量:1张/月数据流编号:D13数据流名称:借书单简述:借阅者所要借书的信息单数据流来源:借阅者数据流去向:审核处理模块数据流组成:图书编号+图书名+借阅证号等数据流量:200张/天高峰流量:400张/天数据流编号:D14数据流名称:不合格借书单简述:经审核处理模块处理后,不合格的借书单数据流来源:审核处理模块数据流去向:借阅者数据流组成:图书编号+图书名+借阅证号等数据流量:50张/天高峰流量:100张/天数据流编号:D15数据流名称:合格的借书单简述:经审核处理后符合规定的借书单数据流来源:审核处理模块数据流去向:书借出处理模块数据流组成:图书编号+图书名+借阅证号等数据流量:200张/天高峰流量:400张/天数据流编号:D16数据流名称:借书清单简述:图书馆所借出图书信息单数据流来源:图书借出处理模块数据流去向:图书库存情况存档数据流组成:图书编号+图书名+借阅证号+管理员编号+日期等数据流量:200张/天高峰流量:400张/天数据流编号:D17数据流名称:借书清单简述:图书馆所借出图书信息单数据流来源:图书借出处理模块数据流去向:借阅者借阅情况存档数据流组成:图书编号+图书名+借阅证号+管理员编号+日期等数据流量:200张/天高峰流量:200张/天数据流编号:D18数据流名称:图书简述:借阅者从图书馆借出的图书数据流来源:图书借出处理模块数据流去向:借阅者数据流组成:图书编号+图书名+条形码号+出版社+出版日期+入库日期+作者+单价等数据流量:300本/天高峰流量:500本/天数据流编号:D19数据流名称:图书简述:借阅者准备归还给图书馆的图书数据流来源:借阅者数据流去向:审核处理模块数据流组成:图书编号+图书名+条形码号+出版社+出版日期+入库日期+作者+单价等数据流量:150本/天高峰流量:400本/天数据流编号:D20数据流名称:罚款通知单简述:审核处理后,发现借阅超期或损坏要求罚款的通知单数据流来源:审核处理模块数据流去向:罚款处理模块数据流组成:借阅证号+管理员编号+金额+日期数据流量:20张/月高峰流量:50张/月数据流编号:D21数据流名称:罚款单简述:对借阅者进行罚款的信息单数据流来源:罚款处理模块数据流去向:借阅者数据流组成:借阅证号+管理员编号+金额+日期数据流量:20张/月高峰流量:50张/月数据流编号:D22数据流名称:应付罚款简述:借阅者因借书超期或损坏图书应该作的赔偿数据流来源:借阅者数据流去向:罚款处理模块数据流组成:金额数据流量:40元/月高峰流量:100元/月数据流编号:D23数据流名称:图书简述:罚款处理后准备入库的图书数据流来源:罚款处理模块数据流去向:图书入库处理模块数据流组成:图书编号+图书名+条形码号+出版社+出版日期+入库日期+作者+单价等数据流量:20本/月高峰流量:50本/月数据流编号:D24数据流名称:图书简述:审核处理后合格的图书数据流来源:审核处理模块数据流去向:图书入库处理模块数据流组成:图书编号+图书名+条形码号+出版社+出版日期+入库日期+作者+单价等数据流量:150本/天高峰流量:400本/天数据流编号:D25数据流名称:还书清单简述:所还图书进行入库信息单数据流来源:图书入库处理模块数据流去向:图书库存情况存档数据流组成:图书编号+图书名+管理员编号+日期等数据流量:150本/天高峰流量:400本/天数据流编号:D26数据流名称:还书清单简述:所还图书进行入库信息单数据流来源:图书入库处理模块数据流去向:借阅者借阅情况存档数据流组成:图书编号+图书名+管理员编号+日期等数据流量:150本/天高峰流量:400本/天数据流编号:D27数据流名称:订书单简述:购买图书计划单数据流来源:采购员数据流去向:判定定货处理模块数据流组成:图书名+图书数量+价格+采购员姓名+采购单位名称+图书出版社+出版日期等数据流量:1张/3个月高峰流量:1张/月数据流编号:D28数据流名称:订书单简述:购买图书计划单数据流来源:判定定货处理模块数据流去向:开付款通知单数据流组成:图书名+图书数量+价格+采购员姓名+采购单位名称+图书出版社+出版日期等数据流量: 1张/3个月高峰流量:1张/月数据流编号:D29数据流名称:付款通知单简述:通知采购方支付货款的信息单数据流来源:开付款通知单数据流去向:采购员数据流组成:货物编号+数量+价格+总金额+供货商编号+供货商名+日期数据流量:1张/3个月高峰流量:1张/月数据流编号:D30数据流名称:订书单简述:购买图书计划单数据流来源:判定订货处理模块数据流去向:开发货票模块数据流组成:图书名+图书数量+价格+采购员姓名+采购单位名称+图书出版社+出版日期等数据流量:1张/3个月高峰流量:1张/月数据流编号:D31数据流名称:订书单简述:购买图书计划单数据流来源:开发货票模块数据流去向:仓库数据流组成:图书名+图书数量+价格+采购员姓名+采购单位名称+图书出版社+出版日期等数据流量:1张/3个月高峰流量:1张月数据流编号:D32数据流名称:发货单简述:通知采购方供货单位开始发货的信息单数据流来源:仓库数据流去向:采购员数据流组成:货物编号+数量+价格+总金额+供货商编号+供货商名+发货日期+采购员编号+采购员姓名等数据流量:1张/3个月高峰流量:1张/月4。
图书馆后台信息管理系统【摘要】图书馆后台信息管理系统是一个为图书馆管理人员提供便捷管理图书馆资源的系统。
本文就该系统的功能特点、使用方法、系统架构、安全性和数据管理进行了详细介绍。
通过该系统,图书馆管理人员可以方便地管理图书借阅信息、查找图书资料,提高工作效率。
系统采用先进的技术架构,保证了系统运行稳定性和数据安全性。
该系统还具有灵活性和可扩展性,可以根据图书馆的具体需求定制功能。
总结来看,图书馆后台信息管理系统为图书馆管理工作带来了便利和效率提升,展望未来,随着技术的不断发展,该系统将进一步完善,为图书馆管理工作带来更多的便利和创新。
【关键词】图书馆后台信息管理系统、引言、介绍、背景、功能特点、使用方法、系统架构、安全性、数据管理、总结、展望1. 引言1.1 介绍图书馆是一个为读者提供信息资源和知识服务的公共机构,为了更好地管理图书馆的各项信息和服务,图书馆后台信息管理系统的出现成为了必然选择。
图书馆后台信息管理系统是图书馆信息化建设的重要组成部分,通过这个系统,图书馆工作人员可以更加高效地管理图书馆的各类信息资源,提供更加便捷的服务。
图书馆后台信息管理系统具有许多功能特点,包括但不限于图书馆资源管理、读者管理、借阅管理、统计分析等功能。
这些功能有效地提高了图书馆工作人员的工作效率,为读者提供了更好的服务体验。
本文将介绍图书馆后台信息管理系统的功能特点、使用方法、系统架构、安全性以及数据管理等方面的内容,希望能够帮助读者更好地了解和使用图书馆后台信息管理系统。
通过本文的介绍,读者可以更深入地了解图书馆后台信息管理系统的重要性和作用,为图书馆信息化建设提供参考和借鉴。
1.2 背景图书馆作为知识的宝库,承载着丰富的文化遗产和学术资源。
随着信息化的发展,图书馆管理也面临着更多的挑战和机遇。
传统的图书馆管理方式已经无法满足现代社会的需求,因此图书馆后台信息管理系统应运而生。
背景:在传统的图书馆管理中,图书的借阅、归还、管理等工作都需要人工操作,效率低下,容易出现错误。
目录1 前言 (1)2 需求分析 (1)2.1 课程设计目的 (1)2.2 课程设计任务 (1)2.3 设计环境 (2)2.4 开发语言 (2)3 分析和设计 (2)3.1 系统E-R模型 (5)3.2 表空间及表的设计 (6)3.3 视图设计 (14)3.4 存储过程、函数、包的设计 (15)3.5 触发器设计 (22)3.6 角色、用户、权限设计 (24)3.7 备份方案设计 (25)4 课程设计总结 (27)参考文献 (28)致谢 (28)1 前言一个简单的图书管理系统包括图书馆内书籍的信息、学校在校师生的信息以及师生的借阅信息。
此系统功能面向图书馆管理员,可以完成书籍和读者的增加、删除和修改,制定借阅规则,以及对读者借阅、续借、归还、预约的确认。
2 需求分析2.1 课程设计目的通过专业课程设计Ⅱ,即大型数据库系统课程设计,有助于培养学生综合运用数据库相关知识解决实际问题的能力。
本设计要求对实际问题进行需求分析,提炼实际问题中的数据,建立关系模型,并在大型数据库中得以实现。
同时要求对数据库的运营、管理及使用上进行必要的规划和实现。
2.2 课程设计任务(1)图书信息:包括图书编号、图书名称、所属类别等;(2)读者信息:包括读者编码、姓名、性别、专业等;(3)借还书信息:包括图书当前状态、被借还次数、借阅时间等。
基本要求:(1)根据需求,补充必要的数据库实体,建立ER模型,通过ER图表示。
(2)在Oracle中创建该系统的数据库,并在数据库中实现各表,写入一定的数据。
(3)从实际查询应用出发,为一些主要的应用模块设计至少3个参数化视图。
(4)从数据检验的角度出发,为相关的表建立至少1个触发器。
(5)从数据更新或修改的角度出发,设计至少1个存储过程。
(6)从安全的角度出发,规划系统的角色、用户、权限,并通过相关的SQL实现。
(7)预计每个表的大致容量和增长速度,指定备份的方案,写出相关的备份命令。
1、1 系统分析1、1、1 图书馆管理信息系统的基本任务“图书馆管理信息系统”就是一个面向具有万人以上用户,位于某中型企事业单位内的图书馆管理系统,藏书规模约100多万册,每天的借阅量近万册。
在手工操作方式下,图书的编目与借阅等工作量大,准确性低且不易修改维护,读者借书只能到图书馆手工方式查找书目,不能满足借阅需求。
需要建立一套网络化的电子图书馆信息系统。
该系统服务对象有两部分人:注册用户与一般读者。
一般读者经注册后成为注册用户,注册用户可以在图书馆借阅图书,其她人员只可查阅图书目录,但不能借阅图书。
系统同时考虑提供电子读物服务,目前只提供电子读物的目录查询服务,不久的将来将提供电子读物全文服务。
用户可通过网络方式访问图书馆管理信息系统。
1、1、2 系统内部人员结构、组织及用户情况分析为了对系统有一个大致了解,现给出系统内部人员结构、组织及用户情况等基本信息。
图书馆管理系统的组织结构如图1.1 所示。
图1、1 图书馆管理信息系统的组织结构图书馆由馆长负责全面工作,下设办公室、财务室、采编室、学术论文室、图书借阅室、电子阅览室、期刊阅览室与技术支持室。
各部门的业务职责如下。
办公室:办公室协助馆长负责日常工作,了解客户需求,制定采购计划。
财务室:财务室负责财务方面的工作。
采编室:采编室负责图书的采购,入库与图书编目,编目后的图书粘贴标签,并送图书借阅室上架。
学术论文室:负责学术论文的收集整理。
图书借阅室:提供对读者的书目查询服务与图书借阅服务。
电子阅览室:收集整理电子读物,准备提供电子读物的借阅服务,目前可以提供目录查询。
期刊阅览室:负责情况的收集整理与借阅。
技术支持室:负责对图书馆的网络与计算机系统提供技术支持。
1.1.3系统业务流程分析系统的业务流程要达到的业务目标,业务流程分析就是系统分析的基础环节。
图书馆管理信息系统的业务流程如图1.2所示。
图1、2 图书馆管理信息系统的业务流程通过业务流程调查,理清图书馆管理系统的主要业务与业务的流程。
图书馆管理系统---类目录1. DataBase.cs 数据库类 (2)2.AdminManage.cs (管理员类) (7)3. BookcaseManage.cs (书架类) (11)4. BookManage.cs(图书信息类) (14)5. BorrowandBackManage.cs(图书借还类) (22)6. BTypeManage.cs(图书类型类) (30)7. LibraryManage.cs(图书馆信息类) (34)8. OperatorClass.cs(日期管理类) (37)9. PubManage.cs(出版社类) (39)10. PurviewManage.cs(管理员权限类) (42)11. ReaderManage.cs(读者信息类) (46)12. RTypeManage.cs(读者类型类) (54)13. ValidateClass.cs 控件校验类 (57)1. DataBase.cs 数据库类using System;using System.Data;using System.Configuration;using System.Web;using System.Web.Security;using System.Web.UI;using System.Web.UI.WebControls;using System.Web.UI.WebControls.WebParts;using System.Web.UI.HtmlControls;using System.Data.SqlClient;///<summary>/// DataBase 的摘要说明///</summary>public class DataBase:IDisposable{public DataBase(){//// TODO: 在此处添加构造函数逻辑//}private SqlConnection con; //创建连接对象#region打开数据库连接///<summary>///打开数据库连接.///</summary>private void Open(){// 打开数据库连接if (con == null){con = new SqlConnection(ConfigurationManager.AppSettings["ConnectionString"]); }if (con.State == System.Data.ConnectionState.Closed)con.Open();}#endregion#region关闭连接///<summary>///关闭数据库连接///</summary>public void Close(){if (con != null)con.Close();}#endregion#region释放数据库连接资源///<summary>///释放资源///</summary>public void Dispose(){// 确认连接是否已经关闭if (con != null){con.Dispose();con = null;}}#endregion#region传入参数并且转换为SqlParameter类型///<summary>///转换参数///</summary>///<param name="ParamName">存储过程名称或命令文本</param>///<param name="DbType">参数类型</param></param>///<param name="Size">参数大小</param>///<param name="Value">参数值</param>///<returns>新的 parameter 对象</returns>public SqlParameter MakeInParam(string ParamName, SqlDbType DbType, int Size, object Value) {return MakeParam(ParamName, DbType, Size, ParameterDirection.Input, Value);}///<summary>///初始化参数值///</summary>///<param name="ParamName">存储过程名称或命令文本</param>///<param name="DbType">参数类型</param>///<param name="Size">参数大小</param>///<param name="Direction">参数方向</param>///<param name="Value">参数值</param>///<returns>新的 parameter 对象</returns>public SqlParameter MakeParam(string ParamName, SqlDbType DbType, Int32 Size, ParameterDirection Direction, object Value){SqlParameter param;if (Size > 0)param = new SqlParameter(ParamName, DbType, Size);elseparam = new SqlParameter(ParamName, DbType);param.Direction = Direction;if (!(Direction == ParameterDirection.Output && Value == null))param.Value = Value;return param;}#endregion#region执行参数命令文本(无数据库中数据返回)///<summary>///执行命令///</summary>///<param name="procName">命令文本</param>///<param name="prams">参数对象</param>///<returns></returns>public int RunProc(string procName, SqlParameter[] prams){SqlCommand cmd = CreateCommand(procName, prams);cmd.ExecuteNonQuery();this.Close();//得到执行成功返回值return (int)cmd.Parameters["ReturnValue"].Value;}///<summary>///直接执行SQL语句///</summary>///<param name="procName">命令文本</param>///<returns></returns>public int RunProc(string procName){this.Open();SqlCommand cmd = new SqlCommand(procName, con);cmd.ExecuteNonQuery();this.Close();return 1;}#endregion#region执行参数命令文本(有返回值)///<summary>///执行查询命令文本,并且返回DataSet数据集///</summary>///<param name="procName">命令文本</param>///<param name="prams">参数对象</param>///<param name="tbName">数据表名称</param>///<returns></returns>public DataSet RunProcReturn(string procName, SqlParameter[] prams, string tbName) {SqlDataAdapter dap = CreateDataAdaper(procName, prams);DataSet ds = new DataSet();dap.Fill(ds, tbName);this.Close();//得到执行成功返回值return ds;}///<summary>///执行命令文本,并且返回DataSet数据集///</summary>///<param name="procName">命令文本</param>///<param name="tbName">数据表名称</param>///<returns>DataSet</returns>public DataSet RunProcReturn(string procName, string tbName){SqlDataAdapter dap = CreateDataAdaper(procName, null);DataSet ds = new DataSet();dap.Fill(ds, tbName);this.Close();//得到执行成功返回值return ds;}#endregion#region将命令文本添加到SqlDataAdapter///<summary>///创建一个SqlDataAdapter对象以此来执行命令文本///</summary>///<param name="procName">命令文本</param>///<param name="prams">参数对象</param>///<returns></returns>private SqlDataAdapter CreateDataAdaper(string procName, SqlParameter[] prams){this.Open();SqlDataAdapter dap = new SqlDataAdapter(procName, con);mandType = CommandType.Text; //执行类型:命令文本if (prams != null){foreach (SqlParameter parameter in prams)dap.SelectCommand.Parameters.Add(parameter);}//加入返回参数dap.SelectCommand.Parameters.Add(new SqlParameter("ReturnValue", SqlDbType.Int, 4, ParameterDirection.ReturnValue, false, 0, 0,string.Empty, DataRowVersion.Default, null));return dap;}#endregion#region将命令文本添加到SqlCommand///<summary>///创建一个SqlCommand对象以此来执行命令文本///</summary>///<param name="procName">命令文本</param>///<param name="prams"命令文本所需参数</param>///<returns>返回SqlCommand对象</returns>private SqlCommand CreateCommand(string procName, SqlParameter[] prams){// 确认打开连接this.Open();SqlCommand cmd = new SqlCommand(procName, con);mandType = CommandType.Text; //执行类型:命令文本// 依次把参数传入命令文本if (prams != null){foreach (SqlParameter parameter in prams)cmd.Parameters.Add(parameter);}// 加入返回参数cmd.Parameters.Add(new SqlParameter("ReturnValue", SqlDbType.Int, 4,ParameterDirection.ReturnValue, false, 0, 0,string.Empty, DataRowVersion.Default, null));return cmd;}#endregion}2.AdminManage.cs (管理员类)using System;using System.Data;using System.Configuration;using System.Web;using System.Web.Security;using System.Web.UI;using System.Web.UI.WebControls;using System.Web.UI.WebControls.WebParts;using System.Web.UI.HtmlControls;using System.Data.SqlClient;///<summary>/// AdminManage 的摘要说明///</summary>public class AdminManage{public AdminManage(){//// TODO: 在此处添加构造函数逻辑//}DataBase data = new DataBase();#region定义管理员信息--数据结构private string id = "";private string name = "";private string pwd = "";///<summary>///管理员编号///</summary>public string ID{get { return id; }set { id = value; }}///<summary>///管理员名称///</summary>public string Name{get { return name; }set { name = value; }}///<summary>///管理员密码///</summary>public string Pwd{get { return pwd; }set { pwd = value; }}#endregion#region自动生成管理员编号///<summary>///自动生成管理员编号///</summary>///<returns></returns>public string GetAdminID(){DataSet ds = GetAllAdmin("tb_admin");string strAdminID = "";if (ds.Tables[0].Rows.Count == 0)strAdminID = "GLY1001";elsestrAdminID = "GLY" + (Convert.ToInt32(ds.Tables[0].Rows[ds.Tables[0].Rows.Count - 1][0].ToString().Substring(3, 4)) + 1);return strAdminID;}#endregion#region添加--管理员信息///<summary>///添加--管理员信息///</summary>///<param name="adminmanage"></param>///<returns></returns>public int AddAdmin(AdminManage adminmanage){SqlParameter[] prams = {data.MakeInParam("@id", SqlDbType.VarChar, 50, adminmanage.ID),data.MakeInParam("@name", SqlDbType.VarChar, 50,),data.MakeInParam("@pwd", SqlDbType.VarChar, 30, adminmanage.Pwd),};return (data.RunProc("INSERT INTO tb_admin (id,name,pwd) VALUES(@id,@name,@pwd)", prams));}#endregion#region修改--管理员信息///<summary>///修改--管理员信息///</summary>///<param name="adminmanage"></param>///<returns></returns>public int UpdateAdmin(AdminManage adminmanage){SqlParameter[] prams = {data.MakeInParam("@name", SqlDbType.VarChar, 50,),data.MakeInParam("@pwd", SqlDbType.VarChar, 30, adminmanage.Pwd),};return (data.RunProc("update tb_admin set pwd=@pwd where name=@name", prams));}#endregion#region删除--管理员信息///<summary>///删除--管理员信息///</summary>///<param name="adminmanage"></param>///<returns></returns>public int DeleteAdmin(AdminManage adminmanage){SqlParameter[] prams = {data.MakeInParam("@name", SqlDbType.VarChar, 50,),};return (data.RunProc("delete from tb_admin where name=@name", prams));}#endregion#region管理员登录///<summary>///管理员登录///</summary>///<param name="adminmanage"></param>///<returns></returns>public DataSet Login(AdminManage adminmanage){SqlParameter[] prams = {data.MakeInParam("@name", SqlDbType.VarChar, 50,),data.MakeInParam("@pwd", SqlDbType.VarChar, 30, adminmanage.Pwd),};return(data.RunProcReturn("SELECT * FROM tb_admin WHERE (name = @name) AND (pwd = @pwd)", prams, "tb_admin"));}#endregion#region查询--管理员信息///<summary>///根据管理员名称得到--管理员信息///</summary>///<param name="adminmanage"></param>///<param name="tbName"></param>///<returns></returns>public DataSet GetAllAdminByName(AdminManage adminmanage, string tbName){SqlParameter[] prams = {data.MakeInParam("@name", SqlDbType.VarChar, 50, +"%"),};return (data.RunProcReturn("select * from tb_admin where name like @name", prams, tbName));}///<summary>///得到所有--管理员信息///</summary>///<param name="tbName"></param>///<returns></returns>public DataSet GetAllAdmin(string tbName){return (data.RunProcReturn("select * from tb_admin ORDER BY id", tbName)); }#endregion}3. BookcaseManage.cs (书架类)using System;using System.Data;using System.Configuration;using System.Web;using System.Web.Security;using System.Web.UI;using System.Web.UI.WebControls;using System.Web.UI.WebControls.WebParts;using System.Web.UI.HtmlControls;using System.Data.SqlClient;///<summary>/// BookcaseManage 的摘要说明///</summary>public class BookcaseManage{public BookcaseManage(){//// TODO: 在此处添加构造函数逻辑//}DataBase data = new DataBase();#region定义书架信息--数据结构private string id = "";private string name = "";///<summary>///书架编号///</summary>public string ID{get { return id; }set { id = value; }}///<summary>///书架名称///</summary>public string Name{get { return name; }set { name = value; }}#endregion#region自动生成书架编号///<summary>///自动生成书架编号///</summary>///<returns></returns>public string GetBcaseID(){DataSet ds = GetAllBCase("tb_bookcase");string strBcaseID = "";if (ds.Tables[0].Rows.Count == 0)strBcaseID = "SJ1001";elsestrBcaseID = "SJ" + (Convert.ToInt32(ds.Tables[0].Rows[ds.Tables[0].Rows.Count - 1][0].ToString().Substring(2, 4)) + 1);return strBcaseID;}#endregion#region添加--书架信息///<summary>///添加--书架信息///</summary>///<param name="bookcasemanage"></param>///<returns></returns>public int AddBookcase(BookcaseManage bookcasemanage){SqlParameter[] prams = {data.MakeInParam("@id", SqlDbType.VarChar, 30, bookcasemanage.ID),data.MakeInParam("@name", SqlDbType.VarChar, 50,),};return (data.RunProc("INSERT INTO tb_bookcase (id,name) VALUES(@id,@name)", prams)); }#endregion#region修改--书架信息///<summary>///修改--书架信息///</summary>///<param name="bookcasemanage"></param>///<returns></returns>public int UpdateBookcase(BookcaseManage bookcasemanage){SqlParameter[] prams = {data.MakeInParam("@id", SqlDbType.VarChar, 30, bookcasemanage.ID),data.MakeInParam("@name", SqlDbType.VarChar, 50,), };return (data.RunProc("update tb_bookcase set name=@name where id=@id", prams)); }#endregion#region删除--书架信息///<summary>///删除--书架信息///</summary>///<param name="bookcasemanage"></param>///<returns></returns>public int DeleteBookcase(BookcaseManage bookcasemanage){SqlParameter[] prams = {data.MakeInParam("@id", SqlDbType.VarChar, 30, bookcasemanage.ID),};return (data.RunProc("delete from tb_bookcase where id=@id", prams));}#endregion#region查询--书架信息///<summary>///根据--书架编号--得到书架信息///</summary>///<param name="bookcasemanage"></param>///<param name="tbName"></param>///<returns></returns>public DataSet FindBCaseByID(BookcaseManage bookcasemanage, string tbName){SqlParameter[] prams = {data.MakeInParam("@id", SqlDbType.VarChar, 30, bookcasemanage.ID+"%"),};return (data.RunProcReturn("select * from tb_bookcase where id like @id", prams,tbName));}///<summary>///根据--书架名称--得到书架信息///</summary>///<param name="bookcasemanage"></param>///<param name="tbName"></param>///<returns></returns>public DataSet FindBCaseByName(BookcaseManage bookcasemanage, string tbName){SqlParameter[] prams = {data.MakeInParam("@name", SqlDbType.VarChar, 50,+"%"),};return (data.RunProcReturn("select * from tb_bookcase where name like @name", prams, tbName));}///<summary>///得到所有--书架信息///</summary>///<param name="tbName"></param>///<returns></returns>public DataSet GetAllBCase(string tbName){return (data.RunProcReturn("select * from tb_bookcase ORDER BY id", tbName));}#endregion}4. BookManage.cs(图书信息类)using System;using System.Data;using System.Configuration;using System.Web;using System.Web.Security;using System.Web.UI;using System.Web.UI.WebControls;using System.Web.UI.WebControls.WebParts;using System.Web.UI.HtmlControls;using System.Data.SqlClient;///<summary>/// BookManage 的摘要说明///</summary>public class BookManage{public BookManage(){//// TODO: 在此处添加构造函数逻辑//}DataBase data = new DataBase();#region定义图书信息--数据结构private string bookcode = "";private string bookname = "";private string type = "";private string author = "";private string translator = "";private string pubname = "";private decimal price = 0;private int page = 0;private string bcase = "";private int storage = 0;private DateTime intime = Convert.ToDateTime(DateTime.Now.ToShortDateString());private string oper = "";private int borrownum = 0;///<summary>///条形码///</summary>public string BookCode{get { return bookcode; }set { bookcode = value; }}///<summary>///书名///</summary>public string BookName{get { return bookname; }set { bookname = value; }}///<summary>///类型编号///</summary>public string Type{get { return type; }set { type = value; }}///<summary>///作者///</summary>public string Author{get { return author; }set { author = value; }}///<summary>///译者///</summary>public string Translator{get { return translator; }set { translator = value; } }///<summary>///出版社///</summary>public string PubName{get { return pubname; }set { pubname = value; }}///<summary>///价格///</summary>public decimal Price{get { return price; }set { price = value; }}///<summary>///页码///</summary>public int Page{get { return page; }set { page = value; }}///<summary>///书架///</summary>public string Bcase{get { return bcase; }set { bcase = value; }}///<summary>///库存量///</summary>public int Storage{get { return storage; }set { storage = value; } }///<summary>///录入时间///</summary>public DateTime InTime{get { return intime; }set { intime = value; }}///<summary>///操作员///</summary>public string Oper{get { return oper; }set { oper = value; }}///<summary>///借阅次数///</summary>public int BorrowNum{get { return borrownum; }set { borrownum = value; } }#endregion#region添加--图书信息///<summary>///添加--图书信息///</summary>///<param name="bookmanage"></param>///<returns></returns>public int AddBook(BookManage bookmanage){SqlParameter[] prams = {data.MakeInParam("@bookcode", SqlDbType.VarChar, 30, bookmanage.BookCode),data.MakeInParam("@bookname", SqlDbType.VarChar, 50,bookmanage.BookName ),data.MakeInParam("@type", SqlDbType.VarChar, 50, bookmanage.Type ),data.MakeInParam("@author", SqlDbType.VarChar, 50, bookmanage.Author ),data.MakeInParam("@translator", SqlDbType.VarChar, 50, bookmanage.Translator ), data.MakeInParam("@pubname", SqlDbType.VarChar, 100, bookmanage.PubName ),data.MakeInParam("@price", SqlDbType.Money, 8, bookmanage.Price ),data.MakeInParam("@page", SqlDbType.Int, 4,bookmanage.Page ),data.MakeInParam("@bcase", SqlDbType.VarChar, 50, bookmanage.Bcase ),data.MakeInParam("@storage", SqlDbType.BigInt, 8, bookmanage.Storage ),data.MakeInParam("@inTime", SqlDbType.DateTime, 8, bookmanage.InTime ),data.MakeInParam("@oper", SqlDbType.VarChar, 30, bookmanage.Oper ),};return (data.RunProc("INSERT INTO tb_bookinfo(bookcode,bookname,type,author,translator,pubname,price,page,bcase,storage,inTime,oper) "+ "VALUES(@bookcode,@bookname,@type,@author,@translator,@pubname,@price,@page,@bcase,@storage,@inTime ,@oper)", prams));}#endregion#region修改--图书信息///<summary>///修改--图书信息///</summary>///<param name="bookmanage"></param>///<returns></returns>public int UpdateBook(BookManage bookmanage){SqlParameter[] prams = {data.MakeInParam("@bookcode", SqlDbType.VarChar, 30, bookmanage.BookCode),data.MakeInParam("@bookname", SqlDbType.VarChar, 50,bookmanage.BookName ),data.MakeInParam("@type", SqlDbType.VarChar, 50, bookmanage.Type ),data.MakeInParam("@author", SqlDbType.VarChar, 50, bookmanage.Author ),data.MakeInParam("@translator", SqlDbType.VarChar, 50, bookmanage.Translator ), data.MakeInParam("@pubname", SqlDbType.VarChar, 100, bookmanage.PubName),data.MakeInParam("@price", SqlDbType.Money, 8, bookmanage.Price ),data.MakeInParam("@page", SqlDbType.Int, 4,bookmanage.Page ),data.MakeInParam("@bcase", SqlDbType.VarChar, 50, bookmanage.Bcase ),data.MakeInParam("@storage", SqlDbType.BigInt, 8, bookmanage.Storage ),data.MakeInParam("@inTime", SqlDbType.DateTime, 8, bookmanage.InTime ),data.MakeInParam("@oper", SqlDbType.VarChar, 30, bookmanage.Oper),};return (data.RunProc("update tb_bookinfo setbookname=@bookname,type=@type,author=@author,translator=@translator,pubname=@pubname,price=@ price,"+ "page=@page,bcase=@bcase,storage=@storage,inTime=@inTime,oper=@oper where bookcode=@bookcode", prams));}///<summary>///每借一次图书就将图书的所借次数加一///</summary>///<param name="bookmanage"></param>///<returns></returns>public int UpdateBorrowNum(BookManage bookmanage){SqlParameter[] prams = {data.MakeInParam("@bookcode", SqlDbType.VarChar, 30, bookmanage.BookCode),data.MakeInParam("@borrownum", SqlDbType.Int, 4, bookmanage.BorrowNum), };return (data.RunProc("update tb_bookinfo set borrownum=@borrownum wherebookcode=@bookcode", prams));}#endregion#region删除--图书信息///<summary>///删除--图书信息///</summary>///<param name="bookmanage"></param>///<returns></returns>public int DeleteBook(BookManage bookmanage){SqlParameter[] prams = {data.MakeInParam("@bookcode", SqlDbType.VarChar, 30, bookmanage.BookCode),};return (data.RunProc("delete from tb_bookinfo where bookcode=@bookcode", prams));}#endregion#region查询--图书信息///<summary>///根据--图书编号--得到图书信息///</summary>///<param name="bookmanage"></param>///<param name="tbName"></param>///<returns></returns>public DataSet FindBookByCode(BookManage bookmanage, string tbName){SqlParameter[] prams = {data.MakeInParam("@bookcode", SqlDbType.VarChar, 30, bookmanage.BookCode+"%"),};return (data.RunProcReturn("select * from tb_bookinfo where bookcode like @bookcode", prams, tbName));}///<summary>///根据--图书名称--得到图书信息///</summary>///<param name="bookmanage"></param>///<param name="tbName"></param>///<returns></returns>public DataSet FindBookByName(BookManage bookmanage, string tbName){SqlParameter[] prams = {data.MakeInParam("@bookname", SqlDbType.VarChar,50,"%"+bookmanage.BookName+"%"),};return (data.RunProcReturn("select * from tb_bookinfo where bookname like @bookname", prams, tbName));}///<summary>///根据--图书类型--得到图书信息///</summary>///<param name="bookmanage"></param>///<param name="tbName"></param>///<returns></returns>public DataSet FindBookByType(BookManage bookmanage, string tbName){SqlParameter[] prams = {data.MakeInParam("@type", SqlDbType.VarChar, 50, "%"+bookmanage.Type+"%"),};return (data.RunProcReturn("select * from tb_bookinfo where type like @type", prams,}///<summary>///根据--图书作者--得到图书信息///</summary>///<param name="bookmanage"></param>///<param name="tbName"></param>///<returns></returns>public DataSet FindBookByAuthor(BookManage bookmanage, string tbName){SqlParameter[] prams = {data.MakeInParam("@author", SqlDbType.VarChar, 50, "%"+bookmanage.Author +"%"),};return(data.RunProcReturn("select * from tb_bookinfo where author like @author", prams, tbName));}///<summary>///根据--出版社--得到图书信息///</summary>///<param name="bookmanage"></param>///<param name="tbName"></param>///<returns></returns>public DataSet FindBookByPub(BookManage bookmanage, string tbName){SqlParameter[] prams = {data.MakeInParam("@pubname", SqlDbType.VarChar, 100, "%"+bookmanage.PubName +"%"),};return (data.RunProcReturn("select * from tb_bookinfo where pubname like @pubname", prams, tbName));}///<summary>///根据--书架--得到图书信息///</summary>///<param name="bookmanage"></param>///<param name="tbName"></param>///<returns></returns>public DataSet FindBookByBCase(BookManage bookmanage, string tbName){SqlParameter[] prams = {data.MakeInParam("@bcase", SqlDbType.VarChar, 50, "%"+bookmanage.Bcase +"%"),};return (data.RunProcReturn("select * from tb_bookinfo where bcase like @bcase", prams,}///<summary>///得到所有--图书信息///</summary>///<param name="tbName"></param>///<returns></returns>public DataSet GetAllBook(string tbName){return (data.RunProcReturn("select * from tb_bookinfo ORDER BY bookcode", tbName));}///<summary>///得到图书借阅排行的前5名///</summary>///<param name="tbName"></param>///<returns></returns>public DataSet GetBookSort(string tbName){return (data.RunProcReturn("select top 5* from tb_bookinfo where borrownum<>0 ORDER BY borrownum desc", tbName));}///<summary>///得到所有图书借阅排行///</summary>///<param name="tbName"></param>///<returns></returns>public DataSet GetAllBookSort(string tbName){return (data.RunProcReturn("select * from tb_bookinfo where borrownum<>0 ORDER BY borrownum desc", tbName));}#endregion}5. BorrowandBackManage.cs(图书借还类)using System;using System.Data;using System.Configuration;using System.Web;using System.Web.Security;using System.Web.UI;using System.Web.UI.WebControls;using System.Web.UI.WebControls.WebParts;using System.Web.UI.HtmlControls;using System.Data.SqlClient;///<summary>/// BorrowandBackManage 的摘要说明///</summary>public class BorrowandBackManage{public BorrowandBackManage(){//// TODO: 在此处添加构造函数逻辑//}DataBase data = new DataBase();#region定义图书借还信息--数据结构private string id = "";private string readid = "";private string bookcode = "";private DateTime borrowtime = Convert.ToDateTime(DateTime.Now.ToShortDateString());private DateTime ygbacktime = Convert.ToDateTime(DateTime.Now.ToShortDateString());private DateTime sjbacktime = Convert.ToDateTime(DateTime.Now.ToShortDateString());private string borrowoper = "";private string backoper = "";private bool isback = false;private string bookname = "";private string name = "";private DateTime fromtime = Convert.ToDateTime(DateTime.Now.ToShortDateString());private DateTime totime = Convert.ToDateTime(DateTime.Now.ToShortDateString());///<summary>///借书编号///</summary>public string ID{get { return id; }set { id = value; }}///<summary>///读者编号。
DB&SQL课程设计(图书馆管理系统数据库)一.图书馆管理数据库LMS,包括的数据表有:Reader(读者表),Book(藏书表),Borrow(借阅表),Kind(分类表)数据:07001 梁斯文男2207002 祁贺男2207003 冯华男2207004 宋志南男2207005 徐文飞男2207006 程小龙男2207007 叶斌男2207008 梁鹏男22(2)Book表结构:数据:EN0001 新视野大学英语郑书棠外语教学与研究出版社EN0002 大学英语四级考试王长喜中山大学出版社EN003 大学英语新标准大训练董军义中国社会出版社MA0001 离散数学屈婉玲清华大学出版社MA0002 萨姆·劳埃德的数学题马丁·加德纳上海科技教育出版社TP0001 现代操作系统Andrew S.Tanenbaum 机械工业出版社TP0002 C程序设计谭浩强清华大学出版社TP0004 Java语言程序设计Y.Daniel Liang 机械工业出版社TP0005 计算机网络谢希仁电子工业出版社TP0006 数据库系统概论萨师煊王珊高等教育出版社ZS0001 毛泽东思想本书编写组高等教育出版社(3)Borrow表结构:备注:年份:格式:xxxx-xx-xx,前xxxx为年份,中间的xx为月份,最后xx为日期;数据:EN0001 07007 2007-05-01 NULLMA0001 07001 2007-03-11 2007-03-30MA0001 07002 2007-06-01 NULLMA0002 07001 2007-05-02 2007-05-03ZS0001 07007 2007-04-27 2007-05-7(3)Kind表结构:备注:分类:格式:xx;数据:EC 财经类TP 计算机类MA 数学类EN 英语类ZS 政治思想类1. 实现功能:查询某年书刊的借阅情况;入口参数:年份:格式:xxxx;说明:(1)由于需要按照借阅记录查询,因此需要建立借阅的游标。
目录1.设计背景------------------------------------------------------------------22.需求分析------------------------------------------------------------------23.功能说明------------------------------------------------------------------24.概念结构设计--------------------------------------------------------------3 4.1实体------------------------------------------------------------------3 4.2局部视图--------------------------------------------------------------34.3完整的E-R图----------------------------------------------------------55.逻辑结构设计--------------------------------------------------------------6 5.1 将E-R图转化为关系模式------------------------------------------------7 5.2 关系模式的优化--------------------------------------------------------75.3 数据库的结构----------------------------------------------------------76.物理结构设计--------------------------------------------------------------9 6.1 索引表的建立----------------------------------------------------------96.2 表空间的建立----------------------------------------------------------107.数据库的实施--------------------------------------------------------------10 7.1系统实验要求-----------------------------------------------------------10 7.2表的建立与数据的载入---------------------------------------------------10 7.3触发器的设计-----------------------------------------------------------10 7.4 数据库的运行----------------------------------------------------------10 7.5 数据库的查询----------------------------------------------------------101.设计背景数据库及其应用系统是具有管理功能的计算机系统,而数据库原理及应用课程设计在开发应用程序中至关重要,合理的数据表结构不尽有利于软件的快速开发,而且有利于以后对软件的维护。
《数据库应用系统》实验报告院系:班级:学号:姓名:一、功能需求说明和分析本实验要求实现一个图书管理系统,系统功能需求说明如下:系统设置:参数、读者类型、图书类型、出版社、预约天数、管理员权限等的设置;系统管理:书籍资料、读者资料的管理和数据导入;基本操作:书籍借阅、续借、归还,新增书籍、读者,读者挂失、注销、退卡,书籍注销,丢失罚款;系统查询:书籍资料、借阅、归还等的查询,读者资料、超期未还、书籍注销的查询;统计分析:书籍、读者资料分类统计,书籍、读者借阅排行榜;罚款租金:可以进行罚款或租金的操作,并进行统计汇总;系统维护:备份、还原数据库,管理员登录密码修改。
针对上述需求说明,对该系统的需求进行进一步的分析如下:管理员权限:1.图书的录入,查询,修改和注销;2.读者信息的添加,修改,查询和注销;3.个人账号登录,查看个人信息,修改密码,退出登录;4.管理和授予读者借书权限;5.正常还书和违规还书。
读者权限:1.图书检索;2.登录,查看个人信息,查看借阅记录,退出登录;3.借书,还书;4.续借已借书籍,预约书籍;5.挂失和退卡注销。
书籍检索:1.读者可检索到自己想要的书籍的基本信息2.可以按照书籍排行榜查看书籍相关书籍二、需求分析数据流图(DFD)表达了数据和处理过程的关系,根据需求分析得到数据流图如下图所示。
数据字典(DD)是系统中各类数据描述的集合,是进行详细的数据收集和数据分析所获得的主要成果。
因此,图书馆信息管理系统数据流程图中,数据信息和处理过程需要通过数据字典才能描述清楚。
在我们定义的图书馆信息管理系统数据字典中,主要对数据流程图中的数据结构、数据存储和处理过程进行说明。
1、数据结构反应了数据之间的组合关系,主要数据结构定义如下:1)数据结构名称:管理员信息含义说明:管理员信息反应了管理员的一些相关信息组成:编号+姓名+登录密码2)数据结构名称:读者信息含义说明:读者信息反应了读者的一些相关信息组成:卡号+姓名+性别+类别+单位3)数据结构名称:图书信息含义说明:图书信息反应了图书的一些相关信息组成:书号+书名+作者+分类+出版社+状态+入库日期+数量4)数据结构名称:借阅记录含义说明:借阅记录反应了每一本书的被借阅历史和每一位读者的借阅历史组成:书号+卡号+借出日期+归还日期2、数据存储是数据结构停留或者保存的地方,主要数据存储定义如下:1)数据存储名称:管理员信息表输入:管理员的工作编号输出:管理员的基本信息数据结构:编号+姓名+登录密码说明:编号是唯一的,且不能为空,作为主码2)数据存储名称:读者信息表输入:读者的借书卡卡号输出:读者的基本信息以及借阅记录数据结构:卡号+姓名+性别+类别+单位说明:卡号是唯一的,且不能为空,作为主码3)数据存储名称:图书信息表输入:图书的书号输出:该图书的状态(已借出/馆内阅读/在架上)和被借阅历史数据结构:书号+书名+作者+分类+出版社+状态+入库日期+数量说明:书号是唯一的,且不能为空,作为主码4)数据存储名称:借阅记录表输入:书籍的书号,或者读者的借书卡卡号输出:相应的借阅记录数据结构:书号+卡号+借出日期+归还日期说明:书号-卡号作为主码;在读者-书籍关系中,卡号为主码,书号为外码;在书籍读者关系中,书号为主码,卡号为外码3、处理过程的具体处理逻辑一般用判定表或者判定树来描述,在数据字典中只需要描述处理过程的说明性信心。
长沙理工大学《程序设计实践》课程设计报告邹松林学院计通学院专业计算机科学与技术班级计算机03-05 学号27学生姓名邹松林指导教师卢曼莎课程成绩完成日期2006年9月20号图书馆管理系统数据库分析与设计学生姓名:邹松林指导老师:卢曼莎摘要:图书信息管理系统主要由读者信息管理模块,图书信息管理模块,借阅信息管理模块,系统信息管理模块等组成。
其中又各自分成读者注册,证件修改,用户注销,图书查询,操作记录等子模块。
在设计本系统过程中,我们第一步由自顶而下的需求分析概括设计出系统总模块的数据流图,再设计个子模块的相应数据流图,列出数据流信息及数据字典;第二步概念设计在需求分析基础上用E-R图表示出数据及相互间联系,采用先作子图,再合并成初步E-R图,进行修改和重构后得到基本E-R图;第三步逻辑设计,在SQL Server的设计环境下把图书馆管理系统E-R图转化为成逻辑数据模型表示的逻辑模式,同时实现数据模型的优化和数据模式的规范化;第四步进行物理设计设计数据的内模式,确定数据的存储结构,存取路径,存储空间分配等等,具体形式为表,视图,索引的建立。
关键字:数据库,SQL语言,MS SQL Server,图书管理1 需求分析用户的需求具体体现在各种信息的提供、保存、更新和查询,这就要求数据库结构能充分满足各种信息的输入和输出。
收集基本数据,数据结构以及数据处理的流程,为后面的具体设计打下基础。
在仔细分析调查有关图书馆管理信息需求的基础上,我们主要考虑以下几个方面的需求:1) 用户需求:图书用户要求计算机系统和SQL Server所工作的范围;2) 应用资源:数据库应用的平台包括物理平台和图书等;3) 应用质量和可靠性要求:包括操作人员素质和系统的纠错能力等1.1 项目名称:图书馆信息管理系统1.2 项目背景和内容概要对图书馆管理信息系统进行详细地分析后,我们将系统分为以下几个模块:借阅管理模块、借书证信息管理模块、图书信息管理模块、系统管理模块。
数据库课程设计报告-——图书馆管理系统学院:计算机科学与技术班级:姓名:学号:指导老师:目录1引言 (1)1。
1.............................................................................................................................. 编写目的11。
2.............................................................................................................................. 开发背景12需求描述 (1)2.1系统目标 (1)2.2用户的特点 (1)2.3需求定义 (2)2.4性能需求 (3)2。
5其他需求 (3)2.6运行环境规定 (3)3数据流图 (3)4概念模型设计 (4)4。
1................................................................................ 相关实体、主要属性以及关系说明:44。
2............................................................................................................... 局部的E—R图:54.3全局E-R图: (6)5逻辑模型设计 (7)5。
1.............................................................................................................................. 数据字典75。
1。
1 book信息表: (7)5。