数据库系统实验报告-图书馆管理计划系统oracle+java.doc
《数据库系统实验报告-图书馆管理计划系统oracle+java.doc》由会员分享,可在线阅读,更多相关《数据库系统实验报告-图书馆管理计划系统oracle+java.doc(23页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、湖南科技大学数学与计算科学学院数据库系统课 程 设 计 课程设计题目: 图书馆管理系统 指导教师: 刘*芳 学生院系: 数学学院 学生班级: 信计*班 学生姓名: 黎*文 学生学号: 14070204* 目 录一、任务书1二、相关技术与环境介绍2三、需求分析2四、概念结构设计3五、逻辑结构设计5六、数据库实施6 6.1 数据库的建立和表空间的建立6 6. 2 数据库用户的建立7 6.3 java前端编程8 6.3.4 功能完善13七、系统测试方案和测试报告13八、系统的主要功能和使用说明14 8.1 功能说明:14 8.2 使用说明14 8.3 图书管理系统数据库安全:15九.系统安装说明15
2、 9.1 数据库的安装15 9.2 java前端程序的安装15十.课程设计心得15 10.1 实验心得16 10.2 总结16一.任务书1.题目:图书馆管理系统2. 内容及要求: (1)创建数据库存储信息 (2)开发java前端程序,使用数据库。 (3)具有实际应用价值3.实验成员分工:黎*文:主要负责物理结构,数据库实施,数据库与前端的连接处理操作。沈*杰:主要负责系统界面、概念与逻辑结构的设计,并进行维护调试。二.相关技术与环境介绍开发工具:oracle 11g,Eclipse 4.5开发语言:Java开发环境:JDK 1.8运行环境:Windows 10 其他辅助工具:PowerDesi
3、gner165,edrawmax核心技术:JOBC对数据库的操作,java操作界面的设计,各种布局方式和插件 (1)使用JFrame控件进行界面设计 (2)使用静态字段实现窗体间的数据传递 (3)使用代码方式向容器控件中添加控件 (4)数据库连接和前台操作 (5)数据库和开发工具之间的编码转换三.需求分析图书馆管理系统是一个高度集成的图书信息处理系统,通过将图书馆的各种功能进行整合,从而达到显示检索信息,提高工作效率,降低管理成本等目的。一个典型的图书馆管理系统应该能够管理所有的图书种类,图书信息以及读者信息,还需要提供各种图书信息的检索查询功能。该系统还需要能够对图书的借阅,归还进行管理,并
4、对读者的罚款进行自动计算。通过该系统的自动化管理,能够大大减少图书馆管理人员,还能减少管理人员的工作任务,从而降低管理开销和成本。一个完整的图书馆管理系统包括前台和后台,前台主要是显示在计算机屏幕上的显示界面,有各种指令按钮,操作框以及文本框,后台主要是为前台的一些操作提供一些必要的数据,也就是一个相对于系统比较完整的数据库,操作员以及各类图书的信息,借书者的信息等等。此次的图书馆管理系统有如下几个重要功能:(1)管理员可以方便进行图书管理,用户管理,管理员管理。图书管理包括图书信息以及图书分类的添加,修改,删除。用户管理包括用户信息的添加,删除,修改。管理员管理包括管理员信息的添加,删除,修
5、改等。(2)管理员可以修改自己的以及用户密码,修改前需先核实自己的原始密码。(3)实现模糊查询,使用户得到更多的相关记录。并且考虑使用的方便性,一些经常使用的输入无须用户输入,比如进行图书查询时图书分类只须用户做选择就可以。(4)如果出现超期未还的情况,能够就做出记录,并作出相应处罚处理。四.概念结构设计4.1 E-R图的设计(1) 学生E-R图: 学 号姓 名借书权限年 龄联系方式学 生性 别登录密码专 业 (2)管理员E-R图:权 限 管理员密 码名 称 (3):图书E-R图:名 称出版社购买时间 图 书是否预约作 者 书 号是否借阅(4)数据库关系图:管 理M学生用户N管理员管 理N管
6、理MNMM图 书N1N管 理管 理1管 理1超级管理员(5)系统逻辑图:4 .2 数据库的设计(1) 建立orcl数据库(2) 建立LIBRARYTEST表空间(3) 在表空间中建立用户libadmin,进行权限的设置,为最高权限(4) 登录libadmin用户,创建libstudent用户,只具有查询的权限(5) 根据4.1中(4)图建立7个表。五.逻辑结构设计1 . 图书(BOOK)的逻辑结构: 2. 超期图书(ECEEDTIME):3. 丢失图书(LOSERBOOK): 4. 管理员权限表(MSANAGER):5. 预约图书:6. 借阅记录:7. 学生用户:以上为各种表的逻辑结构。 六.
7、数据库实施6.1 数据库的建立和表空间的建立 直接在oracle数据库OEM 企业管理其中直接操作。界面化操作省略。6. 2 数据库用户的建立 (1)/创建libadmin用户:conn system /Kyq020520 /登录system 超级用户create user libadminidentified by 123456default tablespace LIBRARYTESTgrant create session,resource to libadmingrant create user,resource to libadmin (2)/创建libstudent用户conn s
8、ystem /Kyq020520 /登录libadmin 用户create user libstudentidentified by 123456default tablespace LIBRARYTESTgrant create session,resource to libstudent (3) 部分权限分配GRANT ALTER ON LIBRARYTEST.BOOK TO LIBADMIN WITH GRANT OPTIONGRANT DELETE ON LIBRARYTEST.BOOK TO LIBADMIN WITH GRANT OPTIONGRANT INDEX ON LIBRA
9、RYTEST.BOOK TO LIBADMIN WITH GRANT OPTIONGRANT INSERT ON LIBRARYTEST.BOOK TO LIBADMIN WITH GRANT OPTIONGRANT REFERENCES ON LIBRARYTEST.BOOK TO LIBADMIN WITH GRANT OPTIONGRANT SELECT ON LIBRARYTEST.BOOK TO LIBADMIN WITH GRANT OPTIONGRANT UPDATE ON LIBRARYTEST.BOOK TO LIBADMIN WITH GRANT OPTION (4)初始数
10、据的插入 给出一个学生表的建立和插入代码: create table student( StuNO int primary key, StuName varchar(50), StuAge int, StuSex varchar(50), Class varchar(50), Department varchar(50), Tel char(11), Permitted varchar(50), Password varchar(20);insert into student values(10001,陈小诗,20,女,计算机1班,计算机系,2592921,是,number1);insert
11、into student values(10002,李飞,21,女,计算机1班,计算机系,13730120123,是,number2);insert into student values(10003,孙亚,20,男,计算机1班,计算机系,13633654578,是,number3);insert into student values(10004,何二,22,男,计算机1班,计算机系,2568975,是,number4);insert into student values(10005,唐雨,21,女,计算机1班,计算机系,13936968956,是,number5);insert into
12、 student values(10006,宋江,20,男,计算机2班,计算机系,1234667,是,number6);6.3 java前端编程 6.3.1 数据库连接类DataBase: package com.listen;import javax.swing.*;import java.sql.*;public class DataBaseConnection con=null;/声明Connection引用Statement stat;ResultSet rs;int count;String sql;public static String message;/声明一个静态成员变量pu
13、blic static Login log;public DataBase(String user,String passWord)try/加载orac的驱动类,并创建数据库连接 Class.forName(oracle.jdbc.driver.OracleDriver); con = DriverManager.getConnection(jdbc:oracle:thin: + 127.0.0.1:1521:orcl,user,passWord); stat=con.createStatement();/创建Statement对象catch(Exception e)/如果从Login类传的参
14、数不对,则提示出错 JOptionPane.showMessageDialog(log,用户IP或端口号错误!+信息,JOptionPane.INFORMATION_MESSAGE);public void selectDb(String sql)/声明select方法tryrs=stat.executeQuery(sql);catch(Exception ie)ie.printStackTrace();public int updateDb(String sql)/声明update方法try/因为oracle数据库的默认编码方式是gbk,而eclipse的默认编码方式也是gbk,所以不存在转
15、码问题/sql = new String(sql.getBytes(),ISO-8859-1);/转码/sql = new String(sql.getBytes(),UTF-8);count=stat.executeUpdate(sql);catch(Exception ie)ie.printStackTrace();return count;public void dbClose()/声明close方法trycon.close();catch(Exception e)e.printStackTrace();public static void main(String args) DataB
16、ase app = new DataBase(libadmin, Kyq020520); try app.rs = app.stat.executeQuery(select * from STUDENT);while (app.rs.next() /转化数据类型 System.out.print(app.rs.getString(STUNO) + ); System.out.println(app.rs.getString(STUNAME) + ); catch (SQLException e) / TODO Auto-generated catch blocke.printStackTrac
17、e()6.3.2 登录界面的设计 登陆窗体的界面设计我依然采用的是比较传统的方法,新建一个类BookLoginFrame类,用来显示登录窗体。在该窗体中需要使用到四类控件,分别是JLabel、JTextFieid、JPasswordField以及JButton。其中控件JLabel是用来显示顶部的图片以及标签文本;控件JTextFieid用来接收用户名输入信息;控件JPasswordField用来接收密码输入信息;控件JButton用来创建登陆和重置按钮。定义一个Login类。设计结果如下: 6.3.3 管理员操作界面 在主窗体中可以显示其他功能窗体,所以需要在该窗体中加入一个桌面窗体。通过将
18、其他功能窗体加入到该窗体中。从而实现多窗体显。同时在主窗口体中,还需要添加一个main方法,该方法为系统入口的方法,通过执行该方法来执行系统。这儿给出他的构造函数:管理面界面操作构造函数:public Root(String mgNo) this.mgNo=mgNo;/获得管理员ID mg=new Manager(mgNo);/创建管理员管理面板 this.setManager();/设置管理员权限 this.initJp();/初始化卡片布局面板 this.addTreeListener();/为树节点注册事件监听器 for(int i=1;i9;i+) /向根节点添加子节点 dtm.ins
19、ertNodeInto(dmtni,dmtn0,i-1); jt.setEditable(false);/设置该树中节点是可编辑的this.add(jsplr);/将包含树的滚动窗口添加进窗体jsplr.setLeftComponent(jt);/将包含树的滚动窗口添加进左边的子窗口jp.setBounds(200,50,600,500);/为jp设置大小位置并添加进右边的子窗口jsplr.setRightComponent(jp); jsplr.setDividerLocation(200);/设置分隔条的初始位置 jsplr.setDividerSize(4);/设置分隔条的宽度 jlRo
20、ot.setFont(new Font(Courier,Font.PLAIN,30);jlRoot.setHorizontalAlignment(JLabel.CENTER);jlRoot.setVerticalAlignment(JLabel.CENTER);/设置窗体的关闭动作,标题,大小,位置及可见性this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); Image image=new ImageIcon(ico.gif).getImage(); this.setIconImage(image);this.setTitle(图书管理系统)
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据库 系统 实验 试验 报告 讲演 呈文 图书馆 藏书楼 管理 计划 规划 oracle java
限制150内