java课程设计图书馆管理系统

上传人:沈*** 文档编号:42435877 上传时间:2021-11-26 格式:DOC 页数:20 大小:91.01KB
返回 下载 相关 举报
java课程设计图书馆管理系统_第1页
第1页 / 共20页
java课程设计图书馆管理系统_第2页
第2页 / 共20页
java课程设计图书馆管理系统_第3页
第3页 / 共20页
点击查看更多>>
资源描述
图书馆管理系统课程设计报告1目录引言-2正文-3结论和建议-4致谢-5参考文献-5附录-5202 引 言当今时代是飞速发展的信息时代。在各行各业中离不开信息处理,这正是计算机被广泛应用于信息管理系统的环境。计算机的最大好处在于利用它能够进行信息管理。使用计算机进行信息控制,不仅提高了工作效率,而且大大的提高了其安全性。尤其对于复杂的信息管理,计算机能够充分发挥它的优越性。计算机进行信息管理与信息管理系统的开发密切相关,系统的开发是系统管理的前提。图书管理系统就是为了管理好图书馆信息而设计的。图书馆作为一种信息资源的集散地,图书和用户借阅资料繁多,包含很多的信息数据的管理,现今,有很多的图书馆都是初步开始使用,甚至尚未使用计算机进行信息管理。根据调查得知,他们以前对信息管理的主要方式是基于文本、表格等纸介质的手工处理,对于图书借阅情况(如借书天数、超过限定借书时间的天数)的统计和核实等往往采用对借书卡的人工检查进行,对借阅者的借阅权限、以及借阅天数等用人工计算、手抄进行。数据信息处理工作量大,容易出错;由于数据繁多,容易丢失,且不易查找。总的来说,缺乏系统,规范的信息管理手段。尽管有的图书馆有计算机,但是尚未用于信息管理,没有发挥它的效力,资源闲置比较突出,这就是管理信息系统的开发的基本环境。数据处理手工操作,工作量大,出错率高,出错后不易更改。图书馆采取手工方式对图书借阅情况进行人工管理,由于信息比较多,图书借阅信息的管理工作混乱而又复杂;一般借阅情况是记录在借书证上,图书的数目和内容记录在文件中,图书馆的工作人员和管理员也只是当时对它比较清楚,时间一长,如再要进行查询,就得在众多的资料中翻阅、查找了,造成查询费时、费力。如要对很长时间以前的图书进行更改就更加困难了。基于这些问题,有必要建立一个图书管理系统,使图书管理工作规范化,系统化,程序化,避免图书管理的随意性,提高信息处理的速度和准确性,能够及时、准确、有效的查询和修改图书情况。3正 文3.1功能需求分析(1)作为学生对图书管理系统的要求有:1. 能按各种方式(比如书名、编号、作者)查询图书馆的藏书情况。2. 能够方便地借阅图书、续借图书、归还图书。3. 能够查询自己的基本资料、借阅图书情况。4. 能够熟悉图书管理系统的使用。(2)作为图书管理员,他们对图书管理系统的要求有:1. 能方便的对图书进行录入登记,注销陈旧的书籍。2. 能够方便地对新生进行登记,或注销已经毕业的学生信息(基本信息,借阅信息)。3. 能够随时发布一些诸如各学院学生借阅图书超期情况、馆内藏书情况、借情况息,以便各学院能够随时获知本院学生的一些借书信息。3.2系统用例分析图书管理系统中包含书籍的采购、入库、编目、出借、归还、淘汰等功能,以及读者信息的管理。本系统对前期的工作进行了简化,删掉了书籍的采购、入库、编目等繁琐的工作,仅对系统主要部分进行分析。为了提高服务效果,图书馆系统实行开架阅览,并为读者提供客户端,读者可以查询到馆藏书目和个人在借图书的信息。这项功能也可以通过互联网实现。图书管理员通过系统记录图书的出借和归还,以及书目的维护和读者信息的维护。3.3系统模块分析3.3.1新书入库模块: (1)新书入库界面包括图书相关的属性:编号、书名、作者、类别、出版日期、出版社、定价、数量、备注等。 3.3.2图书整理模块: (1)图书整理界面包括:图书修改删除、图书类别编辑 图书修改删除界面除了包括图书的相关属性还包括图书修改功能。 图书类别编辑界面包括对类别编号、类别名称进行添加、删除、修改的功模块。3.3.3办借书卡模块:办借书卡界面包括借书卡编号、持借书卡人的姓名、性别、组名、证件号。3.3.4查询模块: (1)借阅信息查询: 根据查询方式如 按借书证号、按姓名等在文本框中输入相关内容即可查询还可查询到期图书 (2)图书信息查询: 查询方式有:按书号、按书名、按作者、按类别、按出版社。在关键字中输入相关内容,点击“开始查询”按钮,在DataList中列出查询结果。如果选中“模糊查询”可查询更多的相关信息。 (3)用户信息查询: 查询方式有:按借书证号、按姓名。在关键字框中输入借书证号或者读者姓名。 组用户管理模块:(4)组用户管理界面: 操作方式包括:修改、删除、添加。 组用户信息包括:组编号、组名称、最长天数、最多本数。3.3.5图书借还模块:图书借阅界面包括图书编号、书名、类别、出版社、出版日期、借书证号等归还图书界面包括图书的属性、归还者的信息。4 总结通过完成本次图书管理系统实践,使我系统的经历了一次JAVA软件开发的整个设计开发过程,把所学的知识综合的运用到这次实践中,重新复习了课本上讲到的知识,觉得有一种温故而知新的感觉,通过实践同时也收获了许多课本上没有的东西。尤其是在开发图书管理系统的过程当中,也遇到了许多技术上或者其他方面的困难,但是也算经过自己的努力,基本上克服了这些困难。由于我的水平确实有限,加之也没有实际的项目经验,设计时间短,所以该系统还有许多不尽如人意的地方,比如功能较少,出错处理不够等多方面问题 ,距离真正实用的图书管理系统还有许多差距,但我相信,软件开发是一个不断完善的过程,我会在以后得学习当中继续完善的 。在这次设计过程中,培养了我的自学能力,在遇到困难的时候,能够认真的对待,不放弃,无论是查看各种书籍还是到图书馆中查找各种资料,想尽一切办法将这个问题解决。我总结了许多编程经验,这将在以后的学习生活中有很大的帮助。5、致谢感谢那些给我带来帮助的书籍和internet,还有周边的同学们。还要感谢我们的指导老师给我们这么多学生的文档认真批改,让我们知道在课程设计与实现的过程中存在的问题。6、参考文献1 王克宏、郝建文. Java技术教程 M. 北京:清华大学出版社,2002年2 基于JAVA的学生信息管理系统 李伟 电子科技大学 【硕士】电子科技大学 2009-04-01 0 578 3 J2EE框架及全文检索技术在信息管理系统中的应用 徐立峰 电子科技大学 【硕士】电子科技大学 2009-10-01 7、附录附部分主要源代码:import javax.swing.*; import java.awt.*;import java.awt.event.*; import javax.swing.table.*;import java.sql.*;import edu.njust.cs.*;public class SimpleBookManagerpublic static void main(String args)SetFont.setFont(new Font(楷体, 0, 12);Connection con=null;trycon=SqlUtil.acquireConnection(127.0.0.1,1433,bookTest,admin,xyz);catch(Exception e)System.out.println(e);System.exit(-1);if(con!=null)JFrame f=new JFrame();f.addWindowListener(new WindowAdapter()public void windowClosing(WindowEvent e)System.exit(0););f.getContentPane().add(new BookManager(f,con);f.setSize(600,400);f.show();class BookManager extends JPanel implements ActionListenerprivate String columnNames=图书编号,书名,定价,出版社;private Class dataType=String.class,String.class,Double.class,String.class;private CustomTableModel model=null;private JTable table=null;private Connection con=null;private JButton btnAdd=new TextAndPicButton(image/addrow20.gif, 增 加 );private JButton btnSearch=new TextAndPicButton(image/search20.gif, 查 询 );private JButton btnDelete=new TextAndPicButton(image/deleterow20.gif, 删 除 );private JButton btnExit=new TextAndPicButton(image/exit20.gif, 退 出 );private JFrame f=null;public BookManager(JFrame f,Connection con)this.f=f;this.con=con;/构建工具条JToolBar toolBar=new JToolBar();toolBar.add(btnAdd);toolBar.add(btnSearch);toolBar.add(btnDelete);toolBar.add(btnExit);/注册事件侦听器btnAdd.addActionListener(this);btnSearch.addActionListener(this);btnDelete.addActionListener(this);btnExit.addActionListener(this);/构建表格model=new CustomTableModel(0,columnNames.length,columnNames,dataType); table = new JTable(model); table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);table.setSelectionMode(ListSelectionModel.SINGLE_SELECTION );/设定表格每列的宽度setTableColumnWidth(0,100);setTableColumnWidth(1,200);setTableColumnWidth(2,100);setTableColumnWidth(3,250);/布局工具条及表格this.setLayout(new BorderLayout();this.add(toolBar,BorderLayout.NORTH);this.add(new JScrollPane(table),BorderLayout.CENTER);/设置表格指定列的宽度public void setTableColumnWidth(int column,int width)if(column=0)TableColumn col=table.getColumn(columnNamescolumn);col.setPreferredWidth(width);public void actionPerformed(ActionEvent e)Object s=e.getSource();if(s=this.btnAdd) add();else if(s=this.btnSearch)search();else if(s=this.btnDelete) delete();else if(s=this.btnExit) System.exit(0);/增加一条记录到数据库public void add()BookEditor be=new BookEditor(f,增加,true);be.show(); /只有点击了信息对话框中的确定按钮,才增加记录if(be.getActionCode()=be.OK)String insertSql=insert into bookInfo VALUES (?,?,?,?);Object lineForDBAdd=be.getID(),be.getBookName(), be.getBookPrice(),be.getBookPress();if(SqlUtil.addRowToDB(con,insertSql,lineForDBAdd) /成功写入数据库的记录,追加到表格的末行显示Object lineForTable= SqlUtil.getLineForTableFromLineForDB(lineForDBAdd,dataType);model.insertRow(model.getRowCount(),lineForTable);/将表格的最后一行选中table.changeSelection(model.getRowCount()-1,0,false,false);elseJOptionPane.showMessageDialog(this,新增时出错!,提示,JOptionPane.INFORMATION_MESSAGE);/查询数据库public void search()SearchDialog sd=new SearchDialog(f,查询,true);sd.show();if(sd.getActionCode()=sd.OK)String readSql=sd.getSQL();SqlUtil.readDBToTable(con,readSql,model,dataType);/删除选定的记录public void delete()int selected=table.getSelectedRow();if(selected=0&selectedmodel.getRowCount()int result=JOptionPane.showConfirmDialog (f,您确定要删除该条图书信息吗? ,确认,JOptionPane.YES_NO_OPTION,JOptionPane.QUESTION_MESSAGE);if (result!=JOptionPane.YES_OPTION)return ;String deleteSql=delete from bookInfo where bookID=?;Object keys=model.getValueAt(selected,0).toString();if(SqlUtil.deleteFromDB(con,deleteSql,keys)model.removeRow(selected);elseJOptionPane.showMessageDialog(f,请选定要删除的一行!,提示,JOptionPane.INFORMATION_MESSAGE);/内部类,用于显示/编辑图书信息的一个模式对话框class BookEditor extends JDialog implements ActionListenerfinal int OK=1; final int CANCEL=-1; final int CLOSE=0;private int actionCode=CANCEL;private JLabel labID=new JLabel( 图书编号 );private JTextField txtID=new JTextField();private JLabel labBookName=new JLabel( 图书名称 );private JTextField txtBookName=new JTextField();private JLabel labBookPrice=new JLabel( 单 价 );private JTextField txtBookPrice=new JTextField();private JLabel labBookPress=new JLabel( 出 版 社 );private JTextField txtBookPress=new JTextField();private JButton btnPre=new JButton(上一个);private JButton btnNext=new JButton(下一个); private JButton btnOk=new JButton(确定);private JButton btnCancel=new JButton(取消);private JFrame f=null;public BookEditor(JFrame f,String s,boolean b)super(f,s,b);this.f=f;/面板p中显示图书信息JPanel p=new JPanel();p.setLayout(new GridBagLayout();LayoutUtil.add(p,GridBagConstraints.NONE, GridBagConstraints.CENTER,0,0,0,0,1,1,labID);LayoutUtil.add(p,GridBagConstraints.HORIZONTAL, GridBagConstraints.CENTER,100,0,1,0,1,1,txtID);LayoutUtil.add(p,GridBagConstraints.NONE, GridBagConstraints.CENTER,0,0,2,0,1,1,labBookName);LayoutUtil.add(p,GridBagConstraints.HORIZONTAL, GridBagConstraints.CENTER,100,0,3,0,1,1,txtBookName);LayoutUtil.add(p,GridBagConstraints.NONE, GridBagConstraints.CENTER,0,0,0,1,1,1,labBookPrice);LayoutUtil.add(p,GridBagConstraints.HORIZONTAL, GridBagConstraints.CENTER,100,0,1,1,1,1,txtBookPrice);LayoutUtil.add(p,GridBagConstraints.NONE, GridBagConstraints.CENTER,0,0,2,1,1,1,labBookPress);LayoutUtil.add(p,GridBagConstraints.HORIZONTAL, GridBagConstraints.CENTER,100,0,3,1,1,1,txtBookPress);/注册事件侦听器btnOk.addActionListener(this);btnCancel.addActionListener(this);btnPre.addActionListener(this);btnNext.addActionListener(this);btnOk.setIcon(new ImageIcon(image/ok20.gif);btnCancel.setIcon(new ImageIcon(image/cancel20.gif);btnPre.setIcon(new ImageIcon(image/pre20.gif);btnNext.setIcon(new ImageIcon(image/next20.gif);btnNext.setHorizontalTextPosition(SwingConstants.LEFT);/在增加模式下前后移动按钮置为不可用/读者扩展该程序具有编辑功能时,可以将前后移动按钮置为可用if(s.equals(增加)btnPre.setEnabled(false);btnNext.setEnabled(false);/面板ap中显示4个按钮JPanel ap=new JPanel();ap.setLayout(new GridBagLayout();LayoutUtil.add(ap,GridBagConstraints.NONE, GridBagConstraints.CENTER,0,0,0,0,1,1,this.btnPre);LayoutUtil.add(ap,GridBagConstraints.NONE, GridBagConstraints.CENTER,0,0,1,0,1,1,this.btnNext);LayoutUtil.add(ap,GridBagConstraints.HORIZONTAL, GridBagConstraints.CENTER,100,0,2,0,1,1,new JLabel();LayoutUtil.add(ap,GridBagConstraints.NONE, GridBagConstraints.CENTER,0,0,3,0,1,1,this.btnOk);LayoutUtil.add(ap,GridBagConstraints.NONE, GridBagConstraints.CENTER,0,0,4,0,1,1,this.btnCancel); getContentPane().add(p,BorderLayout.CENTER);getContentPane().add(ap,BorderLayout.SOUTH);/将对话框窗口定位在父窗口的居中位置setSizeAndPosition(550,120);this.addWindowListener(new WindowAdapter()public void windowClosing(WindowEvent e)actionCode=CLOSE;);/将对话框窗口定位在父窗口的居中位置public void setSizeAndPosition(int w,int h)this.setSize(w,h);Dimension d=f.getSize();Point pp=f.getLocation();this.setLocation(pp.x+(d.width-w)/2,pp.y+(d.height-h)/2);public void actionPerformed(ActionEvent e)Object s=e.getSource();if(s=this.btnCancel)this.actionCode=this.CANCEL;this.setVisible(false);else if(s=this.btnOk) okClicked();public String getID()return txtID.getText().trim();public String getBookName()return txtBookName.getText().trim();/将图书单价由字符串类型转化为Double类型/如果不是合法的数值字符串,取值Double.NEGATIVE_INFINITYpublic Double getBookPrice()double result=Double.NEGATIVE_INFINITY;tryresult=Double.parseDouble(this.txtBookPrice.getText().trim();catch(Exception e)result=Double.NEGATIVE_INFINITY;return new Double(result);public String getBookPress()return txtBookPress.getText().trim();public int getActionCode()return this.actionCode;public void okClicked()/图书编号不为空,且价格为数值类型时 隐藏对话框if(!this.txtID.getText().trim().equals()try Double.parseDouble(this.txtBookPrice.getText().trim();catch(Exception e)JOptionPane.showMessageDialog(f,价格非法!,提示,JOptionPane.INFORMATION_MESSAGE); return ;this.actionCode=this.OK;this.setVisible(false);elseJOptionPane.showMessageDialog(f,请设定图书编号!,提示, JOptionPane.INFORMATION_MESSAGE); class SearchDialog extends JDialog implements ActionListenerfinal int OK=1; final int CANCEL=-1; final int CLOSE=0;private int actionCode=CANCEL;private JRadioButton radID=new JRadioButton( 图书编号 );private JTextField txtID=new JTextField();private JRadioButton radBookName=new JRadioButton( 图书名称 );private JTextField txtBookName=new JTextField();private JRadioButton radBookPress=new JRadioButton( 出 版 社 );private JTextField txtBookPress=new JTextField();private JButton btnOk=new JButton(确定(Yes);private JButton btnCancel=new JButton(取消(Esc); private JFrame f=null;public SearchDialog(JFrame f,String s,boolean b)super(f,s,b);this.f=f;ButtonGroup group=new ButtonGroup();group.add(radID);group.add(radBookName);group.add(radBookPress);txtID.setEditable(false);radBookName.setSelected(true);txtBookPress.setEditable(false);radID.addActionListener(this);radBookName.addActionListener(this);radBookPress.addActionListener(this);/面板p中显示查询条件JPanel p=new JPanel();p.setLayout(new GridBagLayout();LayoutUtil.add(p,GridBagConstraints.NONE, GridBagConstraints.CENTER,0,0,0,0,1,1,radID);LayoutUtil.add(p,GridBagConstraints.HORIZONTAL, GridBagConstraints.CENTER,100,0,1,0,1,1,txtID);LayoutUtil.add(p,GridBagConstraints.NONE, GridBagConstraints.WEST,0,0,0,1,1,1,radBookName);LayoutUtil.add(p,GridBagConstraints.HORIZONTAL, GridBagConstraints.CENTER,100,0,1,1,1,1,txtBookName);LayoutUtil.add(p,GridBagConstraints.NONE, GridBagConstraints.CENTER,0,0,0,2,1,1,radBookPress);LayoutUtil.add(p,GridBagConstraints.HORIZONTAL, GridBagConstraints.CENTER,100,0,1,2,1,1,txtBookPress);btnOk.setIcon(new ImageIcon(image/ok20.gif);btnCancel.setIcon(new ImageIcon(image/cancel20.gif);btnOk.addActionListener(this);btnCancel.addActionListener(this);/面板ap中显示确定 取消按钮JPanel ap=new JPanel();ap.add(btnOk);ap.add(btnCancel);getContentPane().add(p,BorderLayout.CENTER);getContentPane().add(ap,BorderLayout.SOUTH);setSizeAndPosition(300,200);this.addWindowListener(new WindowAdapter()public void windowClosing(WindowEvent e)actionCode=CLOSE;);/将对话框窗口定位在父窗口的居中位置public void setSizeAndPosition(int w,int h)this.setSize(w,h);Dimension d=f.getSize();Point pp=f.getLocation();this.setLocation(pp.x+(d.width-w)/2,pp.y+(d.height-h)/2);public void setTxtEditable(boolean b1,boolean b2,boolean b3)txtID.setEditable(b1);txtBookName.setEditable(b2);txtBookPress.setEditable(b3);public void actionPerformed(ActionEvent e)Object s=e.getSource();if(s=this.radID)setTxtEditable(true,false,false);else if(s=this.radBookName)setTxtEditable(false,true,false);else if(s=this.radBookPress)setTxtEditable(false,false,true);else if(s=this.btnOk)this.actionCode=this.OK;this.setVisible(false);else if(s=this.btnCancel)this.actionCode=this.CANCEL;this.setVisible(false);public int getActionCode()return actionCode;public String getSQL()String sql=select * from bookInfo where ;if(radID.isSelected()sql=sql+ bookID like %+txtID.getText().trim()+%;else if(radBookName.isSelected()sql=sql+ bookName like %+txtBookName.getText().trim()+%;else if(radBookPress.isSelected()sql=sql+ bookPress like %+txtBookPress.getText().trim()+%;return sql;package edu.njust.cs;import java.sql.*;import javax.swing.*;import java.util.*;import java.io.*;public class SqlUtil/读入配置文件public static Properties loadProperty(String fileName)Properties prop=new Properties();tryFileInputStream in=new FileInputStream( System.getProperties().get(user.dir)+/+fileName);prop.load(in);in.close();catch(IOException e)e.printStackTrace();JOptionPane.showMessageDialog(null, 配置文件丢失!n建议重新安装程序, 信息, JOptionPane.ERROR_MESSAGE);prop=null;return prop;/建立和MS SQL SERVER的连接public static Connection acquireConnection(String host,String port,String dbName,String user,String pwd) throws ClassNotFoundException,SQLExceptionConnection connection=null;tryClass.forName(com.microsoft.jdbc.sqlserver.SQLServerDriver);String url =jdbc:microsoft:sqlserver:/+host+:+port+;User=+user+;Password=+pwd; connection= DriverManager.getConnection(url);connection.setCatalog(dbName);catch(ClassNotFoundException e)e.printStackTrace();throw e;catch(SQLException e)e.printStackTrace();throw e;return connection;/使用指定的SQL语句和数据,向数据库插入一条记录public static boolean addRowToDB( Connection con,String insertSql,Object lineForDBAdd)boolean flag=true;PreparedStatement update=null;tryupdate=con.prepareStatement(insertSql);if(lineForDBAdd!=null)for(int i=0;ilineForDBAdd.length;i+)update.setObject(i+1,lineForDBAddi);update.executeUpdate();catch(SQLException e)e.printStackTrace();flag=false;JOptionPane.showMessageDialog(null, 从数据库插入数据时发生错误+e, 信息, JOptionPane.ERROR_MESSAGE);finallyif(update!=null)tryupdate.close();catch(SQLException ex)ex.printStackTrace();return flag;/将适合数据库存储的一行数据(LineForDB)/转化为适合表格显示的数据(LineForTable)/依据数据类型的不同,将代表空值的特殊值转化为空值public static Object getLineForTableFromLineForDB(Object lineForDB,Class dataType)Object lineForTable=new ObjectlineForDB.length;for(int i=0;i0)model.removeRow(0);/从数据库读取数据到表格, dataType指明表格中每一列的数据类型/当前只考虑了String, Double ,Integer,Boolean ,Timestamp类型.public static void readDBToTable(Connection con,String readSql, CustomTableModel model, Class dataType)clearAllRowsInTable(model);PreparedStatement query=null; try query= con.prepareStatement(readSql); query.clearParameters(); ResultSet rs=query.executeQuery(); while(rs.next() int column=model.getColumnCount(); Object line=new Objectcolumn; for(int i=0;icolumn;i+) if(dataTypei=java.lang.String.class)linei=rs.getString(i+1).trim(); else if(dataTypei=java.lang.Double.class) if(rs.getDouble(i+1)=Dou
展开阅读全文
相关资源
相关搜索

最新文档


当前位置:首页 > 办公文档


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!