综合设计报告小型图书管理系统

上传人:仙*** 文档编号:31743874 上传时间:2021-10-12 格式:DOC 页数:35 大小:860.22KB
收藏 版权申诉 举报 下载
综合设计报告小型图书管理系统_第1页
第1页 / 共35页
综合设计报告小型图书管理系统_第2页
第2页 / 共35页
综合设计报告小型图书管理系统_第3页
第3页 / 共35页
资源描述:

《综合设计报告小型图书管理系统》由会员分享,可在线阅读,更多相关《综合设计报告小型图书管理系统(35页珍藏版)》请在装配图网上搜索。

1、综 合 设 计 报 告小型图书管理系统学生姓名:学 号:年级专业:学 院:提交日期:2012年2月23日小型图书管理系统一、实验目的1、 熟练掌握SQL命令2、 掌握Swing图形用户界面编程。3、 掌握java与数据库的连接技术。4、 掌握java.sql包中提供各种类,编写程序实现数据库信息的存取和查询。5、 培养独立查找资料,并解决问题的能力。二、实验任务1、建立一个数据库Library,其中含有如下表格(字段):Books(ISBN,Title,Authors,Publisher,EditionNumber,PublicationDate,Type)Reader(ReaderID,Fi

2、rstName,LastName,Address,PhoneNumber,Limits)Record(RecordID,ISBN,ReaderID,BorrowingDate,ReturnDate)Administrator(administratorID,Password)Student(ReaderID,Password)使用Microsoft SQL Server 2005数据库系统,提前设置好Books,Reader等的数据。2、使用java编程实现如下功能:(1)用户可通过相应界面,依据图书的ISBN,Title,Authors,Publisher,PublicationDate,T

3、ype的组合条件,查询数据库中的符合条件的书籍,程序需将查询结果以表格的方式展示给用户,用户可选择结果排序的依据。(2)提供用户相应的方式借书。当用户选择借阅某本书籍时,应查询该书是否已经被借出:如果被借出,则显示信息(“该书已被借出,归还时间XXXXX”);如该书未被借出,则查阅读者权限(是否超出该读者所能借阅的最大数目书籍),如未超出显示借书成功,并向数据库中增加一条借阅记录,如果超出,则显示信息(“已超过您的最大借阅数目)。(3)提供用户相应的方式还书。还书成功时,将该次的借阅记录删除。(4)修改数据库设计,通过相应界面,提供Reader、Books的增加、删除、修改功能。(5)修改数据

4、库设计,可查询某用户的所有借阅记录。三、开发工具与平台1.开发工具:Eclipse默认是一个和Jbuilder类似的Java开发工具,但它不仅仅只 是Java开发工具,只要装上相应的插件,eclipse也可作为其它语言的开发工具。如C/C+插件(CDT)。2.开发平台:JDK1.73.数据库:Microsoft SQL Server 2005四、设计内容1.界面设计 (1)登录界面(可选择学生用户或者管理员身份)主要采用GridLayout布局管理。(2) 学生用户界面(主要通过JTree和卡片布局) A.卡片布局主要是实现: 当用户通过JTree选择不同功能时,实现右边界面的切换。 B.界面

5、如下:(3) 管理界面的设计此界面主要采用BorderLayout和Box布局方式。2. 逻辑设计图书馆管理系统学生端管理员端查询图书归还图书借阅图书学生用户管理添加图书借阅图书归还图书管理添加加用户管理员规则查询图书2.1、学生用户端l 查询图书,学生用户可以进行简单查询和模糊查询;l 归还图书,学生自动输入自己的ID号,再输入所要还的书,点击确认归还;l 借阅图书,借阅图书,可由学生自行操作,当然这有点不符合图书馆的原则。2.2、管理员端l 学生用户管理,原本打算实现用户信息的增、删、改、查,时间关系此功能并没有实现。l 图书管理,包括图书的增、删、改、查,时间关系,目前也只做了增加图书和

6、查询图书的功能。l 借阅管理,主要是学生借阅图书、归还图书和交纳罚款的管理。l 查询图书,可以进行简单查询和模糊查询。l 归还图书管理,实现学生的还书管理。l 添加新用户,目前只做了学生用户的添加,管理员得添加还要涉及超级管理员的管理,又时间较短,故也没有去实现。3. 程序测试 在程序测试中,主要问题在于组件放到有布局管理器的容器中时,其大小的设置有没有受到影响,比如setAlignmentX(alignmentX)在其他布局管理其中不起作用,只在BOx布局管理器中起作用,网格布局管理器的组件大小(按钮等)大小也没办法自定义大小,介于此,我在写 addBookFrame()和addUserFr

7、ame()两个界面时,采用 setLayout(null),使我能够完全按照自己的意愿来设置各组件的大小,同时也发现,其实布局管理器给我们提供的界面管理,也是非常非常好用好看的。五、附录 用eclipse编写的包及代码: 一 mon.Frame: 管理学生用户和管理员得公共界面,包括借书界面(borrowPanel.java)、登录界面(login.java)、还书界面(returnPanel.java),查询(lookPanel.java)。public class borrowPanel extends JPanel implements ActionListener private fi

8、nal int MAX_STUDENT_BORROW = 6; private JButton yes; private JButton no; private JButton look; private JTable result; private JPanel pNorth; private JPanel p1; private JPanel p2; private JLabel bookISBN; private JTextField isbn; private String c =ISBN,书名,作者,出版社,编号,出版日期,类型; private String data = new

9、String3535; private JScrollPane s; private String readerId; private boolean isLook =false;/是否存在; private String date;/借阅日期; private String rdate;/还书日期; private String DBDriver=com.microsoft.sqlserver.jdbc.SQLServerDriver; private String url = jdbc:sqlserver:/localhost:1433;DatabaseName=Library; priv

10、ate static final long serialVersionUID = -8959055752439578441L; public borrowPanel(String readerId) super(); setName(借阅图书); setSize(450,400); setLayout(new BorderLayout(); setBackground(Color.RED); this.readerId = readerId;/当前登录的读者ID号; Init(); this.add(pNorth,BorderLayout.NORTH); s.setAutoscrolls(tr

11、ue); this.add(s,BorderLayout.CENTER); setVisible(true); private void Init() yes = new JButton(确认借阅);yes.setBorder(BorderFactory.createRaisedBevelBorder();yes.setPreferredSize(new Dimension(150, 30);no = new JButton(取消);no.setBorder(BorderFactory.createRaisedBevelBorder();no.setPreferredSize(new Dime

12、nsion(150, 30);look = new JButton(查询);look.setBorder(BorderFactory.createRaisedBevelBorder();look.setPreferredSize(new Dimension(150, 30);bookISBN = new JLabel(请输入所要借阅的图书ISBN号:);isbn = new JTextField(15);pNorth = new JPanel();pNorth.setLayout(new BorderLayout();p1 =new JPanel();p2 =new JPanel();p1.s

13、etLayout(new FlowLayout();p2.setLayout(new FlowLayout();p2.add(bookISBN,SwingConstants.CENTER);p2.add(isbn);p1.add(yes);p1.add(no);p1.add(look);pNorth.add(p1,BorderLayout.CENTER);pNorth.add(p2,BorderLayout.NORTH);result = new JTable(data,c);s = new JScrollPane(result);look.addActionListener(this);ye

14、s.addActionListener(this);no.addActionListener(this);public void actionPerformed(ActionEvent e) if(e.getSource() = yes)SimpleDateFormat f = new SimpleDateFormat(yyyy.MM.dd);date = f.format(new Date();rdate = returndate(date);if(result.getSelectedRow()=0)&(isLook)borrow();else if(e.getSource() = look

15、) isLook = look();else if(e.getSource() = no)private String returndate(String date2) /归还日期一个月String d = date2.split(.);String str1 = ,str2 = ,str3= ;if(d1.equals(10)|d1.equals(11)|d1.equals(12)if(d1.equals(12) str1 = String.valueOf(Integer.parseInt(d0)+1); str2 = 01; str3 = d2;elsestr1 =d0;int s = I

16、nteger.parseInt(d1)-1;str2 = String.valueOf(s);str3 = d2;else int l = Integer.parseInt(d1.substring(1, 2)+1;str1 = d0;str2 = String.valueOf(l);str3 = d2;return str1+.+str2+.+str3;private void borrow() Connection cn; Statement sm;String bookIsbn = isbn.getText().trim();String sql1 = select * from Rec

17、ord where ISBN = +bookIsbn+;/从Record中查看是否被借走;String sql2 = insert into Record values(null,+bookIsbn+,+readerId+,+date+,+rdate+);/插入到Record;String sql3 = select * from Reader where ReaderID = +readerId+;/查看读者已借阅的图书数;ResultSet rs1,rs2;int isInsert;int readerBook = 0;/已借阅的图书数;try Class.forName(DBDriver

18、); / 加载驱动器cn = DriverManager.getConnection(url, sa, 123456); / 连接数据库sm = cn.createStatement();/查询该读者已借阅的图书数;rs2 = sm.executeQuery(sql3);while(rs2.next()+readerBook;if(readerBook = MAX_STUDENT_BORROW)JOptionPane.showMessageDialog(null, 该读者借阅图书数已超过上限,不能再继续借书);return;else /查询此图书被借阅的情况;rs1 =sm.executeQu

19、ery(sql1);if(!rs1.next()/判断是否已经被别人借走;isInsert = sm.executeUpdate(sql2);if(isInsert = 1)/借书成功JOptionPane.showMessageDialog(null,借阅成功);else JOptionPane.showMessageDialog(null, 借书功能维护中,暂时无法借阅);/end if(isInsert = 1)else String str = rs1.getString(ReturnDate);JOptionPane.showMessageDialog(null, 此图书已被借走,不

20、在架+归还日期+str); / end else cn.close();catch(Exception e)JOptionPane.showMessageDialog(null, 数据库连接失败。);private boolean look() /按ISBN号查询Connection cn; Statement sm;String bookIsbn = isbn.getText().trim();String sql = select * from books where ISBN = +bookIsbn+;ResultSet rs;try Class.forName(DBDriver); /

21、 加载驱动器cn = DriverManager.getConnection(url, sa, 123456); / 连接数据库sm = cn.createStatement();rs = sm.executeQuery(sql);if(rs.next()/如果存在此书; data00 = rs.getString(1); data01 = rs.getString(2); data02 = rs.getString(3); data03 = rs.getString(4); data04 = rs.getString(5); data05 = rs.getString(6); data06

22、= rs.getString(7); repaint(); cn.close(); return true; else cn.close();return false;catch(Exception e)JOptionPane.showMessageDialog(null, 查询失败,请检查连接);return false;public class loginFrame extends JFrame implements ActionListener /* 用户登录界面 */private JLabel numLabel;private JLabel codeLabel;private JLa

23、bel background;private JTextField num;private JPasswordField code;private JButton loginButton;private JButton exitButton;private JPanel pCenter;private JPanel pSouth;private JRadioButton adiministrator;private JRadioButton student;private static final long serialVersionUID = -8959055752439578441L;lo

24、ginFrame()super();setTitle(用户登录);setSize(350,300);/设置窗体大小setResizable(false);/设置不可调窗体大小Dimension dimension = Toolkit.getDefaultToolkit().getScreenSize();/返回窗口的大小setLocation(dimension.width-getWidth()/2,(dimension.height-getHeight()/2);createLoginFrame();getContentPane().add(background,BorderLayout.N

25、ORTH);getContentPane().add(pCenter,BorderLayout.CENTER);getContentPane().add(pSouth,BorderLayout.SOUTH);pack();setVisible(true);private void createLoginFrame() numLabel = new JLabel(用户名,SwingUtilities.CENTER);codeLabel = new JLabel(密码,SwingUtilities.CENTER);background = new JLabel(new ImageIcon(C:Us

26、ersHZLworkspaceLibrarybackgroundlogin.png);num = new JTextField();code = new JPasswordField();code.setEchoChar(*);/设置此 JPasswordField 的回显字符。loginButton = new JButton(登录);loginButton.setBorder(BorderFactory.createRaisedBevelBorder();loginButton.setPreferredSize(new Dimension(150, 30);exitButton = new

27、 JButton(退出);exitButton.setBorder(BorderFactory.createRaisedBevelBorder();exitButton.setPreferredSize(new Dimension(150, 30);pCenter = new JPanel();pSouth = new JPanel();adiministrator = new JRadioButton(管理员);adiministrator.addActionListener(this);student = new JRadioButton(学生);student.addActionList

28、ener(this);loginButton.addActionListener(this);exitButton.addActionListener(this);adiministrator.addActionListener(this);student.addActionListener(this);ButtonGroup group = new ButtonGroup();group.add(adiministrator);group.add(student);pCenter.setLayout(new GridLayout(2,2,3,3); pSouth.setLayout(new

29、GridLayout(2,2,4,4);pCenter.add(numLabel);pCenter.add(num);pCenter.add(codeLabel);pCenter.add(code);loginButton.setPreferredSize(new Dimension(2,2);exitButton.setPreferredSize(new Dimension(2,2);pSouth.add(student);pSouth.add(adiministrator);pSouth.add(loginButton);pSouth.add(exitButton);public stat

30、ic void main(String args) new loginFrame();public void actionPerformed(ActionEvent e) if(e.getSource() = loginButton)&adiministrator.isSelected()if(new Check(num.getText().trim().toString(),String.valueOf(code.getPassword().trim(),A).CheckRight()dispose();new administratorFrame(num.getText().trim();

31、else JOptionPane.showMessageDialog(null, 密码错误或账号不存在,请重新登录);/end loginButton adiministrator.isSelected() else if(e.getSource() = loginButton)&student.isSelected() if(new Check(num.getText().trim(),String.valueOf(code.getPassword().trim(),S).CheckRight()dispose();new studentFrame(num.getText().trim();

32、else JOptionPane.showMessageDialog(null, 密码错误或账号不存在,请重新登录);/end loginButton student.isSelected() else if(e.getSource() = exitButton) System.exit(0); public class lookPanel extends JPanel implements ActionListener private JLabel labelBook;private JTextField textBook;private JPanel p1;private JPanel p

33、2;private JScrollPane s;private CardLayout card;private JButton lookAllButton;private JButton lookButton;private JButton rt;private JTable lookTable;private String c = ISBN, 书名, 作者, 出版社, 编号, 出版日期, 类型 ;private String data = new String2525;private String DBDriver=com.microsoft.sqlserver.jdbc.SQLServer

34、Driver;private String url = jdbc:sqlserver:/localhost:1433;DatabaseName=Library;private static final long serialVersionUID = -8959055752439578441L;public lookPanel() super();setName(查询图书);setSize(250, 300);setBackground(Color.RED);Init();p1.setLayout(new GridLayout(8, 2, 3, 3);for (int i = 0; i labe

35、lBook.length; +i) p1.add(labelBooki);p1.add(textBooki);p1.add(lookButton);p1.add(lookAllButton);lookButton.addActionListener(this);lookAllButton.addActionListener(this);rt.addActionListener(this);lookTable = new JTable(data, c);s = new JScrollPane(lookTable);p2.setLayout(new BorderLayout();p2.add(s,

36、 BorderLayout.CENTER);p2.add(rt, BorderLayout.SOUTH);this.setLayout(card);this.add(p1, 1);this.add(p2, 2);setVisible(true);private void Init() p1 = new JPanel();p2 = new JPanel();rt = new JButton(返回查询条件设置);rt.setBorder(BorderFactory.createRaisedBevelBorder();rt.setPreferredSize(new Dimension(150, 30

37、);lookButton = new JButton(依据参数查询);lookButton.setBorder(BorderFactory.createRaisedBevelBorder();lookButton.setPreferredSize(new Dimension(150, 30);lookAllButton = new JButton(查询全部);lookAllButton.setBorder(BorderFactory.createRaisedBevelBorder();lookAllButton.setPreferredSize(new Dimension(150, 30);l

38、abelBook = new JLabel7;textBook = new JTextField7;for (int t = 0; t labelBook.length; +t) labelBookt = new JLabel(, JLabel.CENTER);textBookt = new JTextField();labelBook0.setText(ISBN);labelBook1.setText(书名);labelBook2.setText(作者);labelBook3.setText(出版社);labelBook4.setText(编号);labelBook5.setText(出版日

39、期);labelBook6.setText(类型);card = new CardLayout();public void actionPerformed(ActionEvent e) if (e.getSource() = lookAllButton) lookAllBook();card.show(this, 2); else if (e.getSource() = lookButton) lookBook();card.show(this, 2); else if (e.getSource() = rt) card.show(this, 1);private void lookBook(

40、) Connection con;Statement stmt;ResultSet result;String sql;String s = new String7;for(int i =0;is.length;+i)si = ;if(!textBook0.getText().trim().equals()s0 = textBook0.getText().trim();sql = select * from Books where ISBN = +s0+;else if(!textBook4.getText().trim().equals()s4 = textBook4.getText().t

41、rim();sql = select * from Books where EditionNumber = +s6+;else sql = select * from Books where Title like %+ s1+% or Type like %+s6+% +or Authors like %+s2+% or Publisher like %+s3+% or PublicationDate like %+s5+% ; int c = 0;try Class.forName(DBDriver); / 加载驱动器con = DriverManager.getConnection(url

42、, sa, 123456); / 连接数据库stmt = con.createStatement();result = stmt.executeQuery(sql);while (result.next() datac0 = result.getString(1);datac1 = result.getString(2);datac2 = result.getString(3);datac3 = result.getString(4);datac4 = result.getString(5);datac5 = result.getString(6);datac6 = result.getStr

43、ing(7);+c;con.close(); catch (Exception e) JOptionPane.showMessageDialog(null, 查询失败,请检查连接);private void lookAllBook() Connection con;Statement stmt;ResultSet result;String sql;int c = 0; sql = select * from Books;try Class.forName(DBDriver); / 加载驱动器con = DriverManager.getConnection(url, sa, 123456);

44、 / 连接数据库stmt = con.createStatement();result = stmt.executeQuery(sql);if (result != null) while (result.next() datac0 = result.getString(1);datac1 = result.getString(2);datac2 = result.getString(3);datac3 = result.getString(4);datac4 = result.getString(5);datac5 = result.getString(6);datac6 = result.

45、getString(7);+c;/ end while()con.close();/ end if catch (Exception e) JOptionPane.showMessageDialog(null, 查询失败,请检查连接情况);public class returnPanel extends JPanel implements ActionListener private JPanel pCenter;/ 用户结束情况显示;private JPanel pNCenter;private JPanel pCCenter;private JPanel pSCenter;private

46、JPanel pSouth;private JLabel labelID;private JTextField textID1;private JButton query;private JButton newQuery;private JTable table;/ 借书情况表;private String c = ISBN, 书名, 作者, 出版社, 编号, 出版日期, 类型 ;private String data = new String3030;private JScrollPane s;private JLabel bookID;private JTextField textID2;

47、private JButton returnButton;private JButton returnUp;/ 返回上级界面; private String DBDriver=com.microsoft.sqlserver.jdbc.SQLServerDriver; private String url = jdbc:sqlserver:/localhost:1433;DatabaseName=Library;private static final long serialVersionUID = -8959055752439578441L;public returnPanel() super

48、();setName(书籍归还管理界面);Dimension d = Toolkit.getDefaultToolkit().getScreenSize();setLocation(d.width - getWidth() / 2 - 350,(d.height - getHeight() / 2 - 350);setSize(600, 650);this.setLayout(new BorderLayout();Init();query.addActionListener(this);newQuery.addActionListener(this);returnButton.addActio

49、nListener(this);returnUp.addActionListener(this);this.add(pCenter, BorderLayout.CENTER);this.add(pSouth, BorderLayout.SOUTH);setVisible(true);private void Init() pCenter = new JPanel();pCenter.setBorder(BorderFactory.createTitledBorder(BorderFactory.createRaisedBevelBorder(), 用户借书情况显示);pNCenter = ne

50、w JPanel();pCCenter = new JPanel();pSCenter = new JPanel();pSouth = new JPanel();labelID = new JLabel(请输入用户ID号);textID1 = new JTextField(15);query = new JButton(查询);query.setBorder(BorderFactory.createRaisedBevelBorder();query.setPreferredSize(new Dimension(60, 20);newQuery = new JButton(新搜索);newQue

51、ry.setBorder(BorderFactory.createRaisedBevelBorder();newQuery.setPreferredSize(new Dimension(60, 20);pNCenter.setLayout(new FlowLayout();pNCenter.add(labelID);pNCenter.add(textID1);pNCenter.add(query);pNCenter.add(newQuery);/ 输入用户IDpCCenter.setBorder(BorderFactory.createTitledBorder(BorderFactory.cr

52、eateRaisedBevelBorder(), 用户借书情况显示);table = new JTable(data, c);s = new JScrollPane(table);pCCenter.add(s);bookID = new JLabel(请输入图书ISBN:);textID2 = new JTextField(15);returnButton = new JButton(还书);returnButton.setBorder(BorderFactory.createRaisedBevelBorder();returnButton.setPreferredSize(new Dimen

53、sion(60, 20);pSCenter.add(bookID);pSCenter.add(textID2);pSCenter.add(returnButton);pCenter.add(pNCenter, BorderLayout.NORTH);pCenter.add(pCCenter, BorderLayout.CENTER);pCenter.add(pSCenter, BorderLayout.SOUTH);pSouth = new JPanel();pSouth.setLayout(new FlowLayout(FlowLayout.CENTER);returnUp = new JB

54、utton(返回);returnUp.setBorder(BorderFactory.createRaisedBevelBorder();returnUp.setPreferredSize(new Dimension(150, 30);pSouth.add(returnUp);Overridepublic void actionPerformed(ActionEvent e) if (e.getSource() = query) query(); else if (e.getSource() = newQuery) textID1.setText(); else if (e.getSource() = returnButton) returnBook(); else if (e.getSource() = returnUp) textID1.setText();textID2.setText();private void returnBook() Connection cn;Statement sm;String bookNum = textID2.getText().trim();String sql = delete from Record where ISBN = + book

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

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

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


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