毕业设计(论文)基于JAVA的图书管理系统设计_第1页
毕业设计(论文)基于JAVA的图书管理系统设计_第2页
毕业设计(论文)基于JAVA的图书管理系统设计_第3页
毕业设计(论文)基于JAVA的图书管理系统设计_第4页
毕业设计(论文)基于JAVA的图书管理系统设计_第5页
已阅读5页,还剩42页未读 继续免费阅读

下载本文档

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

文档简介

1、 图书管理信息系统摘 要图书管理系统是一个典型的信息管理系统(mis),其开发主要包括后台数据库的建立与维护以及前端应用程序的开发两发面。对于前者要求建立起数据一致性和完整性强、数据安全性好的库。而对于后者则要求应用程序功能完备,易使用等特点。这篇论文结合图书馆的要求,对sql server2005数据库管理系统、java语言进行了较深入的学习和应用,主要完成对图书管理系统的需求分析、功能模块划分、数据库模式分析,以用例图表达系统需求, 以设计类图、顺序图、活动图表达系统的结构逻辑及行为逻辑,并由此设计了数据库结构和应用程序。本图书管理系统涵盖了六个主要的子系统:图书管理、读者管理、借书操作、

2、还书操作、新书发布和查询处理,并通过信息的收集、整理、存储、传递将它们有机地结合起来,提高了工作的准确率和效率。系统运行结果证明,本文所设计的图书管理系统可以满足借阅者、图书馆工作人员两方面的需求。【关键词】:数据库,sql server2005,java,图书管理abstractbooks management the system is a typical information management system(mis), its development primarily include the backstage the database of establish with the

3、 development that maintenance and the head apply the procedure two aspect . request to establish to rise the data the consistency with the lib that the complete is strong, data the safety like for the former. but then request the applied procedure the function for the latter complete, easy usage etc

4、. characteristics.therefore oneself combination open into the request that type library, need towards sql server2005 database management system, java proceed in-depthly study with apply, primarily complete to books manage system analysis, function mold the piece divide the line, database mode analys

5、is, combined to from here designed the database the construction with applied procedure. in this system we use the case picture to express the demand of the system, and the class diagram, the sequence diagram and the activity diagram to express the structural logic and behavioral logic in the system

6、. the books management information system has covered six subsystems: the books and reference materials management, the reader material management, taking advantage of the book operation, book launch and also the book operation, inquiry processing, and through the information collection, the reorgan

7、ization, the memory, the transmission organically unifies them, enhanced the work rate of accuracy and the efficiency.the system circulates to pan out the proof, this text books that design management the system can satisfy to borrow the book, library the worker manage the with high class three aspe

8、ct of demand.【 key phrase 】:database, access, visual basic , book management目录 摘 要1abstract11.系统分析61.1需求分析61.1.1开发背景分析61.1.2可行性分析61.1.3功能分析71.1.4运行环境分析71.2组织结构分析71.3业务流程分析71.4数据流程分析91.4.1数据流图0层图101.4.2数据流图1层图111.4.3数据流图2层图112.数据库设计142.1模型 图书馆的卡片142.2数据库表设计152.3表格清单152.3.1表格借阅152.3.2表格图书表162.3.3表格管理员

9、172.3.4表格罚款182.3.5表格读者182.4参考清单192.4.1参考 reference_1202.4.2参考 reference_2202.4.3参考 reference_3212.4.4参考 reference_4213.系统设计223.1模块功能结构设计223.2各功能模块代码设计233.2.1主界面代码设计233.2.2登录界面设计283.2.3用户管理模块界面设计313.2.4借阅管理模块代码设计343.2.5图书管理模块代码设计393.2.6部分功能框架代码(以图书添加为例)453.2.7部分方法定义、数据封装定义(以还书为例)481. 系统分析通过对图书管理系统的分析

10、充分认识系统的目标、系统的各个组成部分、各部分的任务职责、工作流程、数据结构、数据流程等,为系统设计打下基础。系统分析从系统的调查研究入手,包括需求分析、数据结构分析、业务流程分析等。系统分析包括系统内部的各个方面,也包括与系统有联系的各种外部因素。1.1 需求分析1.1.1 开发背景分析xxx学院图书馆需要服务于2000人左右的同学、教师用户,且图书馆藏书上万本,每天借阅量在几百册左右。若在以前的手工操作方式下,不但工作效率低下,工作量大,而且无法收集信息,更谈不上对信息的加工和输出,没法对书的借阅情况进行及时统计并反馈和提供比较快捷的查询书籍等服务。故而开发一套电子图书馆信息管理系统很有必

11、要。并且现代图书馆的管理是通过采编,查询阅读,预约,借还书,数据备份及资料修改整理来实现的,从而可以更加方便、快捷、准确地服务于用户。1.1.2 可行性分析以前,图书馆采用手工方式对图书借阅信息进行管理,将借阅情况记录在借书证上,将图书数目和内容记录在文件中,这样,随着资料的增多,时间的增长,再查询时,就需要在众多的资料中查找,即费时又费力,手工操作使得图书借阅信息的管理工作混乱而复杂。基于以上问题,开发一个智能化的、操作简单、使用方便的图书管理系统是非常有必要的。图书管理系统使图书管理工作规范化、系统化、程序化,避免手工管理的繁琐工作,减少出错的概率,提高信息处理的速度和准确性。图书管理系统

12、是一个典型的数据库应用系统,主要涉及数据读写和数据的传递,利用eclipse工具,采用java语言进行开发不存在技术方面的问题。1.1.3 功能分析图书管理系统需要具备以下主要功能: 图书管理:包括新书采编入库、图书归还和图书基本信息的管理。新书采编入库是将采购归来的书进行编排、整理分类、录入,并贴上条形码。 图书借阅和归还:图书借阅时要对借阅者进行身份的合法性验证;图书归还时对超期的读者,自动计算出罚款金额。 读者管理:实现读者信息的添加、修改、删除和查询等功能。 信息查询:包括图书信息查询、图书借阅信息查询、读者信息查询等功能; 信息发布功能:包括新书发布,借阅超期等;1.1.4 运行环境

13、分析硬件平台: cpu:p1.60ghz; 内存:512m以上;软件平台: 操作系统:win7; 数据库:sql server 2005; 开发工具:jdk 1.6.0 eclipse3.4; 1.2 组织结构分析图书借阅管理系统属于图书馆内部的一种管理系统,通过内部网络处理和交换信息,本例采用单程序模式,客户端与服务器端运行的主体程序相同。只在于不同权限的用户登录有不同的功能权限。为了方便管理,且该图书管理系统规模较小型,故该系统组织上趋于简单化,日常管理维护工作仅需要具有管理员权限登录的用户来进行。需要对系统进行日常维护、查询、管理、统计、修改用户信息。读者用户登录该系统权限仅限于独立借书

14、、查询书籍和个人资料等有限功能。通过这种单程序模式即可实现该系统日常图书管理、借阅等工作。1.3 业务流程分析图书管理员用例图借阅者用例图图书管理系统用例图1.4 数据流程分析数据流图可以清楚的表示各个模块之间的调用关系。以下将数据流图分为三层,分别表示如下:1.4.1 数据流图0层图1.4.2 数据流图1层图1.4.3 数据流图2层图 图书入库采编系统 图书借阅管理系统数据流图 图书查询系统数据流图 图书维护系统数据流图 读者管理系统数据流图 罚金管理系统数据流图 图书预约系统数据流图 图书续借系统数据流图 2. 数据库设计2.1 模型 图书馆的卡片名称图书馆代码图书馆数据库管理系统micr

15、osoft sql server 2005注释数据库2.2 数据库表设计2.3 表格清单名称代码借阅borrow图书表book管理员admin罚款publish读者users2.3.1 表格借阅表格借阅的卡片名称借阅代码borrow 表格借阅的输出参考清单名称代码父表格外键列父角色子角色reference_1reference_1管理员管理员idreference_2reference_2读者用户名reference_3reference_3图书表图书号表格借阅的列清单名称代码还书时间returntime借书时间lendtime管理员idaid用户名uname图书号number是否归还isba

16、ck表格借阅的键清单名称代码主要的key_1key_1true2.3.2 表格图书表表格图书表的卡片名称图书表代码book表格图书表的进入参考清单名称代码子表格外键列父角色子角色reference_3reference_3借阅图书号reference_4reference_4罚款图书号表格图书表的列清单名称代码图书号number图书名bookname出版社publish作者author价格price国际统一编码isbn模式mode分类category表格图书表的键清单名称代码主要的key_1key_1true2.3.3 表格管理员表格管理员的卡片名称管理员代码admin表格管理员的进入参考清单

17、名称代码子表格外键列父角色子角色reference_1reference_1借阅管理员id表格管理员的列清单名称代码管理员idaid管理员编号num管理员姓名aname管理员密码apassword表格管理员的键清单名称代码主要的key_1key_1true2.3.4 表格罚款表格罚款的卡片名称罚款代码publish表格罚款的输出参考清单名称代码父表格外键列父角色子角色reference_4reference_4图书表图书号表格罚款的列清单名称代码罚款编号pid图书号number表格罚款的键清单名称代码主要的key_1key_1true2.3.5 表格读者表格读者的卡片名称读者代码users表格

18、读者的进入参考清单名称代码子表格外键列父角色子角色reference_2reference_2借阅用户名表格读者的列清单名称代码用户名uname学号unumber用户密码upassword用户姓名tname学院collage专业subject年级grade是否借阅borrowed剩余数量left_amount表格读者的键清单名称代码主要的key_1key_1true2.4 参考清单名称代码父表格子表格外键列父角色子角色reference_1reference_1管理员借阅管理员idreference_2reference_2读者借阅用户名reference_3reference_3图书表借阅图

19、书号reference_4reference_4图书表罚款图书号2.4.1 参考 reference_1参考reference_1的卡片名称reference_1代码reference_1子表格借阅父表格管理员外键列管理员id父角色子角色参考reference_1的连接清单父表格列子表格列管理员id管理员id2.4.2 参考 reference_2参考reference_2的卡片名称reference_2代码reference_2子表格借阅父表格读者外键列用户名父角色子角色参考reference_2的连接清单父表格列子表格列用户名用户名2.4.3 参考 reference_3参考referen

20、ce_3的卡片名称reference_3代码reference_3子表格借阅父表格图书表外键列图书号父角色子角色参考reference_3的连接清单父表格列子表格列图书号图书号2.4.4 参考 reference_4参考reference_4的卡片名称reference_4代码reference_4子表格罚款父表格图书表外键列图书号父角色子角色参考reference_4的连接清单父表格列子表格列图书号图书号3. 系统设计3.1 模块功能结构设计根据系统的设计要求,图书管理系统实现了3个完整的图书借阅和数据库维护功能,以保证该系统正常的日常运作。根据这些功能要求,设计的系统功能模块如图4所示。

21、图书管理系统各模块功能要求分析如下:登录管理要求为了方便管理书籍和同时满足大量用户的需求,登录管理设计了两种登录模式:管理员登录和读者登录,依照其密码权限的不同,登录后能独立操作的功能也有所不同,以满足小型图书管理系统的需求。该部分是系统对用户身份进行辨识。首先要求用户输入自己的登录用户名和登录密码,然后系统对用户名和密码进行验证,判断用户身份。用户管理要求由于用户众多,为了方便每个用户借阅,该系统需要存储每个用户的基本信息,以便用户借书时通过用户名从数据库中快速调出用户信息,用户基本信息包括用户名、姓名、密码、学院、专业、年级等,此部分操作只有管理员权限才可以使用,包括添加新用户、查询用户信

22、息、和删除用户。图书管理要求为了方便书籍的管理,需要把每本书的相关信息添加到数据库,以便通过书号从数据库中快速调出用户信息,图书基本信息包括图书名、书号、作者、出版社、出版年月等,管理员可以添加图书、查询统计图书的借阅情况和删除图书以及新书的自动发布。借阅管理要求该系统的核心功能,通过借阅管理与后台数据库相连,将借阅相关信息写进借阅表或读出。拥有管理员权限就可以对任意用户进行图书借阅登记和图书归还登记,并可以对用户进行超期罚金管理和满足用户续借需求。拥有用户权限的读者仅仅只能独立进行借阅操作,并查询到自己的借阅情况如:借阅书籍书目、归还时间等,图书续借功能亦能独立实现。设计较为严谨,以保证用户

23、信息和权利的安全性以及系统的正常有序管理和运行。3.2 各功能模块代码设计3.2.1 主界面代码设计 package com.lsm;import org.eclipse.swt.swt;import org.eclipse.swt.events.mouseevent;import org.eclipse.swt.events.mousetrackadapter;import org.eclipse.swt.events.selectionadapter;import org.eclipse.swt.events.selectionevent;import org.eclipse.swt.wi

24、dgets.display;import org.eclipse.swt.widgets.group;import org.eclipse.swt.widgets.label;import org.eclipse.swt.widgets.menu;import org.eclipse.swt.widgets.menuitem;import org.eclipse.swt.widgets.shell;import com.lsm.dao.dao;import com.lsm.iframe.bookmodiiframe;import com.lsm.iframe.loginiframe;impor

25、t com.swtdesigner.swtresourcemanager;public class library private menuitem newitemmenuitem_10;private menuitem newitemmenuitem_9;private menuitem newitemmenuitem_8;private menuitem newitemmenuitem_3;private menuitem newitemmenuitem_2;private menuitem newitemmenuitem_7;private menuitem newitemmenuite

26、m_6;private menuitem newitemmenuitem_1;private menuitem newitemmenuitem_5;private menuitem newitemmenuitem;private menuitem newitemmenuitem_4;protected shell shell;private static string loginname;private static boolean flag;public static string getlog()return loginname;public static boolean getflag(

27、)return flag;/* * launch the application * param args */public static void main(string args) try /library window = new library();/window.open();loginiframe loginwindow = new loginiframe();loginwindow.open(); catch (exception e) e.printstacktrace();/* * open the window */public void open(boolean unvi

28、sible,string loginname) this.loginname=loginname;this.flag=unvisible;final display display = display.getdefault();createcontents();shell.open();if(unvisible = true)this.setunvisible();shell.layout();while (!shell.isdisposed() if (!display.readanddispatch()display.sleep();/* * create contents of the

29、window */protected void createcontents() shell = new shell();shell.setbackgroundimage(swtresourcemanager.getimage(library.class, /1.jpg);shell.setbackground(display.getcurrent().getsystemcolor(swt.color_title_inactive_background_gradient);shell.setime(null);shell.setimage(swtresourcemanager.getimage

30、(library.class, /book.ico);shell.setsize(567, 393);shell.settext(图书管理系统);final menu menu = new menu(shell, swt.bar);shell.setmenubar(menu);final menuitem newsubmenumenuitem = new menuitem(menu, swt.cascade);newsubmenumenuitem.settext(用户管理);final menu menu_1 = new menu(newsubmenumenuitem);newsubmenum

31、enuitem.setmenu(menu_1);newitemmenuitem_4 = new menuitem(menu_1, swt.none);newitemmenuitem_4.addselectionlistener(menuactions.user_add);newitemmenuitem_4.settext(添加用户);newitemmenuitem = new menuitem(menu_1, swt.none);newitemmenuitem.settext(修改与删除用户);newitemmenuitem.addselectionlistener(menuactions.u

32、ser_modify);final menuitem newsubmenumenuitem_1 = new menuitem(menu, swt.cascade);newsubmenumenuitem_1.settext(借阅管理);final menu menu_2 = new menu(newsubmenumenuitem_1);newsubmenumenuitem_1.setmenu(menu_2);newitemmenuitem_3 = new menuitem(menu_2, swt.none);newitemmenuitem_3.settext(借阅图书);newitemmenui

33、tem_3.addselectionlistener(menuactions.borrow);newitemmenuitem_5 = new menuitem(menu_2, swt.none);newitemmenuitem_5.settext(归还与续借图书);newitemmenuitem_5.addselectionlistener(menuactions.give_back);newitemmenuitem_1 = new menuitem(menu_2, swt.none);newitemmenuitem_1.settext(借阅统计);newitemmenuitem_1.adds

34、electionlistener(menuactions.borrow_statistics);newitemmenuitem_8 = new menuitem(menu_2, swt.none);newitemmenuitem_8.settext(预约管理);newitemmenuitem_8.setenabled(false);final menuitem newsubmenumenuitem_2 = new menuitem(menu, swt.cascade);newsubmenumenuitem_2.settext(图书管理);final menu menu_3 = new menu

35、(newsubmenumenuitem_2);newsubmenumenuitem_2.setmenu(menu_3);newitemmenuitem_6 = new menuitem(menu_3, swt.none);newitemmenuitem_6.settext(添加图书);newitemmenuitem_6.addselectionlistener(menuactions.book_add);newitemmenuitem_7 = new menuitem(menu_3, swt.none);newitemmenuitem_7.settext(修改与删除图书);newitemmen

36、uitem_7.addselectionlistener(menuactions.book_modify);newitemmenuitem_9 = new menuitem(menu_3, swt.none);newitemmenuitem_9.settext(查询图书);newitemmenuitem_9.addselectionlistener(menuactions.book_search);newitemmenuitem_2 = new menuitem(menu_3, swt.none);newitemmenuitem_2.settext(图书分类统计);newitemmenuite

37、m_2.addselectionlistener(menuactions.book_statistics);/final menuitem newitemmenuitem_15 = new menuitem(menu_3, swt.none);/newitemmenuitem_2.settext(图书借阅统计);/newitemmenuitem_2.addselectionlistener(menuactions.book_counting);final menuitem newsubmenumenuitem_13 = new menuitem(menu, swt.cascade);newsu

38、bmenumenuitem_13.settext(系统);final menu menu_4 = new menu(newsubmenumenuitem_13);newsubmenumenuitem_13.setmenu(menu_4);newitemmenuitem_10 = new menuitem(menu_4, swt.none);newitemmenuitem_10.addselectionlistener(new selectionadapter() public void widgetselected(final selectionevent e) shell.close();)

39、;newitemmenuitem_10.settext(退出);final group group = new group(shell, swt.none);group.setbackgroundimage(swtresourcemanager.getimage(library.class, /7.jpg);group.setbackground(display.getcurrent().getsystemcolor(swt.color_white);group.settext(新书发布);group.setbounds(268, 60, 207, 126);group.setvisible(

40、false);final label label_1 = new label(group, swt.none);label_1.settext(书名:);label_1.setbounds(10, 24, 42, 13);final label label_1_1 = new label(group, swt.none);label_1_1.setbounds(74, 24, 95, 13);final label label_2 = new label(group, swt.none);label_2.setbounds(10, 50, 42, 13);label_2.settext(书号:

41、);final label label_1_2 = new label(group, swt.none);label_1_2.setbounds(74, 50, 95, 13);final label label_1_3 = new label(group, swt.none);label_1_3.setbounds(74, 76, 95, 13);final label label_2_1 = new label(group, swt.none);label_2_1.setbounds(10, 76, 42, 13);label_2_1.settext(作者:);final label la

42、bel = new label(shell, swt.none);label.setbackgroundimage(swtresourcemanager.getimage(library.class, /6.jpg);label.addmousetracklistener(new mousetrackadapter() public void mouseenter(final mouseevent e) /显示新书信息objectresults=bookmodiiframe.getfilestates(dao.selectpublish();label_1_1.settext(results0

43、1.tostring();label_1_2.settext(results00.tostring();label_1_3.settext(results03.tostring();group.setvisible(true);public void mouseexit(final mouseevent e) group.setvisible(false););label.settext(新书发布);label.setbounds(268, 21, 99, 25);/public void setunvisible()newitemmenuitem.setenabled(false);newi

44、temmenuitem_1.setenabled(false);newitemmenuitem_2.setenabled(false);newitemmenuitem_4.setenabled(false);newitemmenuitem_5.setenabled(false);newitemmenuitem_6.setenabled(false);newitemmenuitem_7.setenabled(false);3.2.2 登录界面设计分为管理员和读者两种身份登录,其用户名和密码分列在两张数据表中,由此可将用户身份区别开,以保证系统的正常维护和用户借书的方便准确性。package co

45、m.lsm.dao;import java.sql.connection;import java.sql.date;import java.sql.drivermanager;import java.sql.resultset;import java.sql.sqlexception;import java.sql.timestamp;import java.util.arraylist;import java.util.list;import com.lsm.model.admin;import com.lsm.dao.dao;import com.lsm.model.user;import

46、 com.lsm.model.bookinfo;import com.lsm.model.borrow;public class dao protected static string dbclassname = com.microsoft.sqlserver.jdbc.sqlserverdriver;protected static string dburl = jdbc:sqlserver:/localhost:1433;+ databasename=lib_manager;selectmethod=cursor;protected static string dbuser = sa;pr

47、otected static string dbpwd = 123;protected static string second = null;private static connection conn = null;private dao() try if (conn = null) class.forname(dbclassname).newinstance();conn = drivermanager.getconnection(dburl, dbuser, dbpwd);elsereturn; catch (exception ee) ee.printstacktrace();/ *

48、 管理员登录方法*/public static admin check(string name, string password) int i = 0;admin operater=new admin();string sql = select * from admin where aname= + name+ and apassword= + password + ;resultset rs = dao.executequery(sql);try while (rs.next() string names = rs.getstring(1);operater.setid(rs.getstri

49、ng(aid);operater.setname(rs.getstring(aname);operater.setnum(rs.getstring(num);operater.setpassword(rs.getstring(apassword);if (names != null) i = 1; catch (exception e) e.printstacktrace();dao.close();return operater;/* 读者登录方法*/public static user checkuser(string name, string password) int i = 0;us

50、er operater=new user();string sql = select * from users where uname= + name+ and upassword= + password + ;resultset rs = dao.executequery(sql);try while (rs.next() string names = rs.getstring(1);operater.setuname(rs.getstring(uname);operater.setupassword(rs.getstring(upassword);if (names != null) i

51、= 1; catch (exception e) e.printstacktrace();dao.close();return operater;3.2.3 用户管理模块界面设计该模块包括对读者用户的删除、修改、添加、查询功能的实现public static int insertusers(string uname,string upassword,string tname,string unumber,string college,string subject,string grade)int i=0;trystring sql=insert into users(uname,upassword

温馨提示

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

评论

0/150

提交评论