




已阅读5页,还剩31页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
安安 徽徽 农农 业业 大大 学学 课程实践(设计)报课程实践(设计)报 告告 实践项目名称 图书管理系统的设计 项目组成人员 院 系 信 年级专业 0 指 导 教 师 傅 目录 1 1 课程设计背景(课程设计背景(包包括:现状、括:现状、研研究目的等)究目的等) .3 3 2 2 需求分析需求分析(包括:功包括:功能能分析、操作流程分析分析、操作流程分析等等) .3 3 2.12.1 需求分析.3 3 3 设计与实设计与实现现(包括:前台页(包括:前台页面面、数据库、业务逻辑等设计)、数据库、业务逻辑等设计) .4 4 3.13.1 数据库结构设计.4 3.1.1 概念结构设计.4 3.1.2 逻辑结构设计 . 7 3.2.1 物理结构设计. 8 3.3.1 系统功能设计图书管理模块功11 34 系统界面设计与实现.11 3.4.1 系统登录界面11 - 3 - 1 课程设计背景课程设计背景 图书馆信息化管理从最初的对图书馆业务管理实行信息化管 理发展到对图书馆各个业务流程和网络化管理,并建立大规模 的以个体文献目录联机查询为主的资源共享系统;而图书馆的 正常运营中总是面对大量的读者信息,图书信息及两者相互作 用产生的借书信息,所以要对读者资源,读者资源,借书信息 进行管理,本系统的开发就是在于提高图书管理的工作效率! 2 需求分析(包括:功能分析、操作流程分析等)需求分析(包括:功能分析、操作流程分析等) 2.1需求分析 一般通用的图书馆借阅管理系统包括系统管理、读者管理、编 目、图书流通、统计、查询等功能。比较先进的能够在一个界 面下实现图书、音像、期刊的管理,设置假期、设置暂离锁 (提高安全性)、暂停某些读者的借阅权、导入导出读者、交 换MARC数据、升级辅助编码库等。此外随着Internet应用的 发展,一个完善的系统还应该提供无缝接入Internet的功能, 通过IE浏览器让读者使用借阅资料查询、更换密码、预约、资 料检索等功能。有些系统还能提供读者自助服务,可以开放一 些客户机让读者自行管理密码、查询自己的借阅史、预约资料、 检索资料等。 - 4 - 在构造系统时,首先从需求出发构造数据库表,然后再由数据 库结合需求划分系统功能模块。这样,就把一个大的系统分解 成了几个小系统。这里把系统的层次划分为了两个部分:一个 是一般用户态:即图书有服务子系统;另一个是管理员界面: 提供图书的管理和维护功能。对于不同子系统之间的功换,采 用了登录功能和用户注销功能。 系统划分了子系统后,下一步的工作是继续划分子系统的小 模块。先考虑在进入子系统时应该做什么,进入系统之后又应 该做什么,提供那些服务等。例如,对于图书信息服务子系统, 在用户进入时首先得调用相关数据库表,找出用户的图书借阅 情况;进入系统后,子系统得提供图书查询、图书借阅和还书 功能。另外,针对本系统的特殊情况,同时也考虑系统的可移 植性,在系统中增加了数据库路径的维护部分。 但由于本人技术有限,下面只做了部分设计但由于本人技术有限,下面只做了部分设计 3 设计与实现(包括:前台页面、数据库、业务逻辑等设计)设计与实现(包括:前台页面、数据库、业务逻辑等设计) 3.1数据库结构设计 3.1.1 概念结构设计(E-R图) - 5 - 概念结构设计是将分析得到的用户需求抽象为概念模型的 过程,即在需求分析的基础上,设计出能够满足用户需求的各 种实体以及它们之间的相互关系的模型。这样才能更好地、更 准确地用某一DBMS实现这些需求,它是整个数据库设计的关 键。概念结构的主要特点是能真实、充分地反映现实世界,易 于理解,易于更改,易于向关系、网状、层次等各种数据模型 转换。描述概念模型的有力工具是E-R模型。 Er 图:图: 管理 管理 管理 管理 管理 管理员 图书类型 书架 图书 图书馆信 息 借阅信息 属于 属于 - 6 - 部分实体部分实体 ER 图:图: 图书 书名 作者 书类 书架号 价格 管理员 管理员号 管理员名 密码 图书编 号 借阅次数 - 7 - 3.1.2 逻辑结构设计 逻辑结构设计的任务就是把概念结构设计阶段设计好的基本E- R图转换为与选用DBMS产品所支持的数据模型相符合的逻辑 结构。设计逻辑结构时一般要分三步进行,首先是将概念结构 转换为一般的关系、网状、层次模型,其次是将转换来的关系、 网状、层次模型向特定DBMS支持下的数据模型转换,最后是 对数据模型进行优化。 基于B/S的简易图书借阅管理系统采用的是将E-R图向关系数 据模型转换。以下是由概念模型向逻辑模型转化的关系模式: 管理员(管理员编号,管理员名称,管理员密码) 图书(图书编码,图书名称,图书类别,书架,作者,价格, 借阅次数) - 8 - 3.2.1物理结构设计 数据库的物理结构设计是对于给定的逻辑数据模型,选取一个 最合适应用环境的物理结构。数据库的物理结构指的是数据库 在物理设备上的存储结构与存取方法,它依赖于给定的计算机 系统 表2.2管理员信息表(new_userlist) 字段名注释类型长度允许空默认值 userId 管理员 编号 int4 自动增长 (1,1) userName 管理员 名称 varch ar 50Null userPwd 管理员 密码 varch ar 50Null - 9 - 表2.3图书信息表(new_booklist) 字段名 注释 类 型 长度 允 许空 默认值 bookid图书编 码 varc har 50 bookNa me 图书名 称 varc har 50 null bookTyp e 图书类 别 int 4 null bookcase书架int 100 null auother作者varc har 80 null price价格mon ey 8null borrowS um 借阅次 数 int 4 null - 10 - 数据库表: - 11 - 3.3.1系统功能设计图书管理模块功能(时间技术有限目前只有 此功能) 图书类型管理:是对图书进行分类管理,对图书类型的添 加、删除、修改等功能。 图书信息管理:管理员对图书信息的详细录入,修改图书 信息和删除图书信息等功能。 34系统界面设计与实现 3.4.1系统登录界面 系统首页,同时也是登录界面,在此界面中,管理可以根 据自身情况登录到系统中 ,管理员登录界面如下图所示: - 12 - 相关代码: 用户登陆界面 - 13 - 管理员登陆: 管理员姓名 管理员密码 - 14 - 用户身份验证 !- -JSPdl-0 显示图书列表 图书列表 - 17 - 图书编号 书名 作者 书类 书架号 价格 借阅次数 % new_booklistBean records=conn.getAllRecords(); if(records!=null) for(int i=0;i 更多操作: 添加图书 返回 删除图书 管理员添加图书记录: - 19 - 相关代码: JSPdl-3 添加图书记录 - 20 - 添加新记录 图书编号 * 书名 * 作者 书类 书架号 * - 21 - 价格 * 借阅次数 * - 22 - JSPdl-4 删除图书记录 图书列表 图书编号 书名 作者 书类 书架号 价格 - 23 - 借阅次数 选择 % new_booklistBean records=conn.getAllRecords(); if(records!=null) for(int i=0;i % String check=new Stringrecords.length; for(int i=0;i 与系统相关的bean代码: New_booklistBean - 25 - package beans; public class new_booklistBean private String bookID;/表示书编号; private String bookName;/书名; private String auother;/作者名; private int bookType;/书类; private int bookCase;/书架号; private int price;/书价; private int borrowSum;/书被借的次数; public String getbookID() return bookID; public void setbookID(String bookID) this.bookID = bookID; public String getbookName() return bookName; public void setbookName(String bookName) this.bookName = bookName; public String getauother() return auother; - 26 - public void setauother(String auother) this.auother = auother; public int getbookType() return bookType; public void setbookType(int bookType) this.bookType = bookType; public int getbookCase() return bookCase; public void setbookCase(int bookCase) this.bookCase = bookCase; public int getprice() return price; public void setprice(int price) this.price = price; public int getborrowSum() return borrowSum; public void setborrowSum(int borrowSum) - 27 - this.borrowSum = borrowSum; ConnBean package beans; import java.sql.*; /导入jdbc; public class ConnBean private String driver=sun.jdbc.odbc.JdbcOdbcDriver;/默认驱动程序为jdbc-odbc驱动; private String jdbcurl=jdbc:odbc:;/jdbcurl private String database=new_booklist;/数据库或数据源 private String userName=root;/用户名 private String password=;/密码 private Connection connection=null; public Connection getConnection() try Class.forName(driver);/注册驱动程序; connection=DriverManager.getConnection(jdbc:odbc:new_booklist,);/ 建立连接; catch(ClassNotFoundException e1) e1.printStackTrace(); catch(SQLException e2) e2.printStackTrace(); - 28 - return connection; public void closeConnection(Connection connection)/关闭连接; try if(connection!=null) connection.close(); connection=null; catch(SQLException e3) e3.printStackTrace(); public void closePstmt(PreparedStatement pstmt)/关闭执行语句; try if(pstmt!=null) pstmt.close(); pstmt=null; catch(SQLException e) e.printStackTrace(); public void closeResultSet(ResultSet rs)/关闭结果集语句; try if(rs!=null) rs.close(); - 29 - rs=null; catch(SQLException e) e.printStackTrace(); public String getDriver() /获取驱动程序 return driver; public void setDriver(String driver) this.driver = driver; public String getDatabase() return database; public void setDatabase(String database) this.database = database; public String getPassword() return password; public void setPassword(String password) this.password = password; public String getJdbcurl() return jdbcurl; - 30 - public void setJdbcurl(String url) this.jdbcurl = url; public String getUserName() return userName; public void setUserName(String userName) this.userName = userName; New_libraryBean package beans; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; - 31 - import java.util.ArrayList; import java.util.Collection; public class new_libraryDBean extends ConnBean private Connection connection=null; public new_booklistBean getAllRecords()/获取所有记录 ResultSet rs=null; PreparedStatement pstmt=null; Collection list=new ArrayList(); try connection=getConnection(); pstmt=connection.prepareStatement(select * from new_booklist);/数据 表new_booklist rs=pstmt.executeQuery(); while(rs.next() new_booklistBean new_booklist=new new_booklistBean(); new_booklist.setbookID(rs.getString(1); new_booklist.setbookName(rs.getString(2); new_booklist.setauother(rs.getString(3); new_booklist.setbookType(rs.getInt(4); new_booklist.setbookCase(rs.getInt(5); new_booklist.setprice(rs.getInt(6); new_booklist.setborrowSum(rs.getInt(7); list.add(new_booklist); - 32 - catch(SQLException e) e.printStackTrace(); finally closePstmt(pstmt); closeConnection(connection); new_booklistBean records=(new_booklistBean)list.toArray(new new_booklistBean0); return records; public new_booklistBean queryARecord(String sqlStr)/查询一条记录 ResultSet rs=null; PreparedStatement pstmt=null; new_booklistBean new_booklist=new new_booklistBean(); try connection=getConnection(); pstmt=connection.prepareStatement(sqlStr); rs=pstmt.executeQuery(); if(rs.next() new_booklist.setbookID(rs.getString(1); new_booklist.setbookName(rs.getString(2); new_booklist.setauother(rs.getString(3); new_booklist.setbookType(rs.getInt(4); new_booklist.setbookCase(rs.getInt(5); new_booklist.setprice(rs.getInt(6); - 33 - new_booklist.setborrowSum(rs.getInt(7); catch(SQLException e) e.printStackTrace(); finally closeResultSet(rs); closePstmt(pstmt); closeConnection(connection); return new_booklist; public boolean insertRecord(new_booklistBean record)/插入记录 PreparedStatement pstmt=null; String insStr=insert into new_booklist values (?,?,?,?,?); if(record=null) return false; try connection=getConnection(); pstmt=connection.prepareStatement(insStr); pstmt.setString(1, record.getbookID(); pstmt.setString(2, record.getbookName(); pstmt.setString(3, record.getauother(); pstmt.setInt(4, record.getbookType(); pstmt.setInt(5, record.getbookCase(); pstmt.setInt(6, record.getprice(); pstmt.setInt(7, record.getborrowSum(); - 34 - pstmt.execute(); catch(SQLException e) e.printStackTrace(); finally closePstmt(pstmt); closeConnection(connection); return true; public boolean deleteRecord(new_booklistBean record)/删除记录; PreparedStatement pstmt=null; String delStr=delete from new_booklist where bookID=?; if(record=null) return false; try getC
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 电缆工考试题及答案
- 登高证考试题及答案
- (正式版)DB15∕T 3226-2023 《液化天然气单位产品电耗限额》
- 多平台用户信息整合工具
- 养老护理实操考试试题库及答案
- 大学民歌考试题及答案
- 文化传播推广效果承诺书5篇
- 往日的点烁星光の我愿意一生都在歌唱300字10篇
- 内部协作规定协议的指导
- 公司员工职业发展规划与指导手册
- 无人机集群控制技术-深度研究
- 合伙开工厂 合同范例
- 比亚迪秦EV新能源汽车整车控制系统
- 部编版小学道德与法治六年级上册配套表格式教案(全册)
- 商务星球版八年级地理上册4.1《因地制宜发展农业》听课评课记录
- 厨房6S管理培训
- 锂电池pack生产线可行性报告
- 2025年政府机关《干部履历表》标准模板
- 临床常用他评量表
- (新版)海事集装箱装箱检查员考试题库及答案
- 车位租赁协议
评论
0/150
提交评论