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

java高级图书馆课程设计一、课程目标知识目标:1. 学生能理解并掌握Java高级编程中的面向对象设计原则,包括封装、继承和多态。
2. 学生能够运用Java异常处理机制,编写健壮的图书馆管理系统代码。
3. 学生掌握集合框架的使用,特别是List和Map,实现图书馆书籍和用户的有效管理。
4. 学生理解并运用文件I/O操作,实现对图书馆数据的持久化存储。
技能目标:1. 学生能够设计并实现一个基于Java的图书馆管理系统,具备用户注册、借阅书籍、归还书籍等功能。
2. 学生通过实践,掌握运用Java编程解决实际问题的能力,如设计合理的类和接口、编写方法及调试程序。
3. 学生能够运用所学的Java知识,进行项目需求分析,模块划分,并协同团队完成项目开发。
情感态度价值观目标:1. 学生通过课程学习,培养对编程的兴趣和热情,增强解决复杂问题的自信心。
2. 学生在团队协作中,学会沟通与分享,培养合作精神和集体荣誉感。
3. 学生能够意识到信息技术在图书馆管理等现代服务业中的重要作用,增强社会责任感和创新意识。
本课程设计针对高年级学生,他们在先前课程中已具备Java基础,现通过此课程深化理解,将知识应用于实际项目中。
课程旨在通过图书馆管理系统的设计实践,提高学生的编程能力,同时培养其团队协作和解决问题的综合能力。
二、教学内容1. 面向对象设计原则:复习Java中的类与对象,深入探讨封装、继承和多态的概念及其在实际编程中的应用。
- 教材章节:第五章“面向对象设计”2. Java异常处理:讲解异常的概念、分类,掌握try-catch-finally结构,以及如何创建自定义异常。
- 教材章节:第十章“异常处理”3. 集合框架:学习List、Set、Map等集合接口及其实现类的使用,重点掌握ArrayList、HashMap的应用。
- 教材章节:第八章“集合框架”4. 文件I/O操作:介绍Java中文件读写的基本操作,包括File类、InputStream/OutputStream、Reader/Writer等。
java图书管理系统课程设计

java图书管理系统课程设计一、教学目标本课程旨在通过学习Java图书管理系统,让学生掌握Java编程的基本语法和面向对象编程思想,学会使用Java开发一个简单的图书管理系统。
通过本课程的学习,学生将能够:1.掌握Java基本语法、数据类型、运算符、控制结构等基础知识。
2.理解面向对象编程的基本概念,如类、对象、封装、继承、多态等。
3.学会使用Java开发工具,如Eclipse、IntelliJ IDEA等。
4.熟练使用Java编写图书管理系统的各个模块,如图书添加、删除、查询、借还书等功能。
5.培养学生的编程思维和解决问题的能力。
二、教学内容本课程的教学内容主要包括Java基础知识、面向对象编程、Java开发工具的使用以及图书管理系统的开发。
具体安排如下:1.Java基础知识:第1-4周,学习Java基本语法、数据类型、运算符、控制结构等。
2.面向对象编程:第5-8周,学习类与对象、封装、继承、多态等概念及应用。
3.Java开发工具:第9-10周,学习Eclipse、IntelliJ IDEA等开发工具的使用。
4.图书管理系统开发:第11-16周,通过项目驱动的方式,分模块开发图书管理系统,包括图书添加、删除、查询、借还书等功能。
三、教学方法为了激发学生的学习兴趣和主动性,本课程将采用多种教学方法相结合的方式,如讲授法、讨论法、案例分析法、实验法等。
具体如下:1.讲授法:用于讲解Java基本语法、数据类型、运算符、控制结构等基础知识。
2.讨论法:用于探讨面向对象编程的概念及应用,鼓励学生发表自己的见解。
3.案例分析法:通过分析实际案例,让学生学会使用Java开发图书管理系统。
4.实验法:让学生动手实践,实际编写代码,培养学生的编程能力。
四、教学资源为了支持本课程的教学内容和教学方法的实施,我们将准备以下教学资源:1.教材:《Java核心技术卷I 基础知识》2.参考书:《Java编程思想》3.多媒体资料:教学PPT、视频教程4.实验设备:计算机、网络环境5.在线编程平台:LeetCode、牛客网等,用于学生练习和测试编程能力。
课程设计报告JAVA图书管理系统

//显示删除后数据库记录
ResultSet rs=stmt.executeQuery("select * from books");
DefaultTableModel tableModel= (DefaultTableModel)table.getModel(); tableModel.setRowCount(0); //添加查询到的记录集 while (rs.next()) { String[] arr=new String[6]; arr[0]=rs.getString("bname"); arr[1]=rs.getString("id"); arr[2]=rs.getString("publish"); arr[3]=rs.getString("version"); arr[4]=rs.getString("editor"); arr[5]=rs.getString("count"); tableModel.addRow(arr);
} //刷新表格,即重新绘制 table.invalidate();
rs.close(); stmt.close(); con.close();
} catch(Exception ex)
{ System.out.println(ex.getMessage());
}
} });ห้องสมุดไป่ตู้
/////////////////////////////修改/////////////////////////////// b3.addActionListener(new ActionListener(){
public void actionPerformed(ActionEvent e) {
图书管理系统javaweb课程设计

图书管理系统javaweb课程设计一、教学目标本课程的目标是让学生掌握JavaWeb的基本知识,能够使用JavaWeb技术开发一个简单的图书管理系统。
具体的学习目标包括:1.知识目标:学生需要掌握JavaWeb的基本技术,包括JSP、Servlet、JavaBean等,理解图书管理系统的业务流程。
2.技能目标:学生能够独立开发一个简单的图书管理系统,具备一定的编程能力和问题解决能力。
3.情感态度价值观目标:学生能够理解团队协作的重要性,培养良好的编程习惯,具备一定的创新意识。
二、教学内容教学内容主要包括JavaWeb的基本技术,图书管理系统的业务流程,以及实际操作。
具体的教学大纲如下:1.第一周:介绍JavaWeb的基本概念,学习JSP技术,能够编写简单的JSP页面。
2.第二周:学习Servlet技术,理解图书管理系统的业务流程,编写图书管理的Servlet代码。
3.第三周:学习JavaBean技术,实现图书管理系统的业务逻辑,编写JavaBean代码。
4.第四周:学习如何部署和运行JavaWeb应用,完成图书管理系统的测试和调试。
三、教学方法为了激发学生的学习兴趣和主动性,本课程将采用多种教学方法,包括讲授法、讨论法、案例分析法、实验法等。
具体的使用方法如下:1.讲授法:用于讲解JavaWeb的基本概念和基本语法。
2.讨论法:用于讨论图书管理系统的业务流程和解决方案。
3.案例分析法:通过分析实际案例,让学生理解JavaWeb技术的应用。
4.实验法:通过实际操作,让学生掌握JavaWeb技术的使用。
四、教学资源为了支持教学内容和教学方法的实施,丰富学生的学习体验,我们将选择和准备以下教学资源:1.教材:《JavaWeb程序设计》。
2.参考书:《JavaWeb开发技术详解》。
3.多媒体资料:相关的教学视频和演示文稿。
4.实验设备:计算机和网络设备。
五、教学评估为了全面反映学生的学习成果,本课程将采用以下评估方式:1.平时表现:通过学生的课堂表现、参与讨论的情况等进行评估,占总成绩的20%。
图书信息管理系统java课程设计

图书信息管理系统java课程设计一、课程目标知识目标:1. 学生能理解图书信息管理系统的基本原理,掌握Java语言在系统开发中的应用。
2. 学生能掌握面向对象编程思想,运用类与对象的概念实现系统功能。
3. 学生能了解数据库的基本操作,通过Java实现对图书信息的管理。
技能目标:1. 学生能运用Java语言编写简单的图书信息管理系统,具备基本的编程能力。
2. 学生能通过本课程的学习,掌握分析问题、设计解决方案、编写代码和调试程序的能力。
3. 学生能通过小组合作,提高团队协作和沟通能力。
情感态度价值观目标:1. 学生对Java编程产生兴趣,培养主动学习和解决问题的积极性。
2. 学生在课程学习中,养成认真负责、严谨细致的学习态度。
3. 学生通过本课程的学习,认识到编程在现实生活中的应用价值,激发创新意识。
课程性质:本课程为实践性较强的课程,结合理论教学和实际操作,培养学生的编程能力和实际应用能力。
学生特点:学生处于高年级阶段,已具备一定的Java编程基础,对面向对象编程有一定了解,但实际操作能力有待提高。
教学要求:结合学生特点,注重理论与实践相结合,提高学生的实际操作能力。
将课程目标分解为具体的学习成果,以便在教学过程中进行有效评估。
二、教学内容1. 理论部分:- 图书信息管理系统概述:介绍系统基本功能、模块划分及Java语言在系统开发中的应用。
- 面向对象编程基础:回顾类、对象、继承、封装、多态等概念。
- 数据库基础知识:讲解数据库的基本操作,如创建表、插入数据、查询数据等。
2. 实践部分:- 系统需求分析:指导学生分析图书信息管理系统的功能需求,明确系统目标。
- 系统设计:教授学生如何设计系统架构,划分模块,编写类和接口。
- 编码实现:指导学生运用Java语言编写图书信息管理系统的各个功能模块。
- 系统测试与调试:教授学生如何进行单元测试、集成测试,查找并修复程序错误。
教材章节关联:1. 理论部分:参照教材第3章“Java面向对象编程”和第6章“数据库编程”。
java图书馆管理系统课程设计

Java图书馆管理系统课程设计摘要本文介绍了一个基于Java的图书馆管理系统的课程设计。
该系统旨在帮助图书馆有效地管理图书借阅、归还以及读者信息管理等功能。
系统采用Java语言编写,利用面向对象的思想进行设计与实现,实现了图书的分类管理、借阅记录的管理、读者信息的管理等功能。
通过该系统的设计与实现,方便图书馆管理员进行日常的图书信息管理工作,同时提高读者借阅图书和归还图书的便捷性。
1.引言图书馆作为一个重要的文化及知识传播机构,其管理任务日益复杂。
借助计算机技术的发展,图书馆管理系统帮助图书馆实现了自动化的图书信息管理、借阅管理和读者管理等功能,极大地提高了工作效率与准确性。
本文介绍的Java图书馆管理系统具有以下特点:•使用Java语言编写,具有良好的跨平台性;•采用面向对象的思想设计,具有良好的扩展性与可维护性;•实现了图书分类管理、借阅记录管理、读者信息管理等功能,并提供了相应的操作界面;•提高了图书管理员的工作效率,提供了读者便捷的查询借阅信息和操作的途径。
2.系统设计2.1 需求分析在开始系统设计之前,我们需要对图书馆管理系统的需求进行分析。
根据实际需求,我们确定了以下功能模块:•图书管理:包括图书的添加、删除、修改和查询;•读者管理:包括读者的添加、删除、修改和查询;•借阅管理:包括借阅记录的添加、删除、修改和查询;•统计分析:包括图书借阅量和读者借阅排行等统计分析功能。
2.2 系统架构系统采用三层架构进行设计,分为表示层、业务逻辑层和数据访问层。
•表示层:负责展示图书馆管理系统的界面,接受用户的操作输入,并将输入传递给业务逻辑层进行处理;•业务逻辑层:负责处理用户操作的业务逻辑,包括图书管理、读者管理、借阅管理等功能的实现;•数据访问层:负责与数据库进行数据交互,包括读取图书信息、读者信息、借阅记录信息等。
2.3 类设计在系统设计过程中,我们根据功能模块的需求,设计了以下类:•图书类(Book):表示一本书的信息,包括书名、作者、出版社等;•读者类(Reader):表示一个读者的信息,包括姓名、年龄、性别等;•借阅记录类(BorrowRecord):表示一条借阅记录的信息,包括图书、读者、借阅时间等;•图书管理类(BookManager):实现图书的添加、删除、修改和查询功能;•读者管理类(ReaderManager):实现读者的添加、删除、修改和查询功能;•借阅管理类(BorrowManager):实现借阅记录的添加、删除、修改和查询功能;•统计分析类(StatisticsManager):实现图书借阅量和读者借阅排行等统计分析功能。
图书借阅管理系统java课程设计

图书借阅管理系统java课程设计一、教学目标本节课的学习目标包括以下三个方面:1.知识目标:使学生掌握图书借阅管理系统的基本概念、原理和功能,理解Java语言在图书借阅管理系统中的应用。
2.技能目标:培养学生具备使用Java语言设计和实现图书借阅管理系统的基本能力,提高学生的编程实践能力。
3.情感态度价值观目标:培养学生对计算机科学的兴趣和热情,增强学生对图书借阅管理工作的认识,提高学生的信息素养。
二、教学内容本节课的教学内容主要包括以下几个部分:1.图书借阅管理系统的基本概念和原理:介绍图书借阅管理系统的定义、功能和作用,使学生了解图书借阅管理系统的整体框架。
2.Java语言在图书借阅管理系统中的应用:讲解Java语言的特点和优势,展示Java语言在图书借阅管理系统开发中的应用实例。
3.图书借阅管理系统的设计与实现:引导学生学习图书借阅管理系统的设计方法,培养学生动手实践的能力,使学生能够独立设计和实现简单的图书借阅管理系统。
4.教学案例分析:分析实际的图书借阅管理案例,使学生更好地理解和掌握图书借阅管理系统的原理和应用。
三、教学方法为了实现本节课的教学目标,我们将采用以下几种教学方法:1.讲授法:通过讲解图书借阅管理系统的基本概念、原理和功能,使学生掌握相关知识。
2.案例分析法:分析实际的图书借阅管理案例,引导学生理解和掌握图书借阅管理系统的原理和应用。
3.实验法:学生进行图书借阅管理系统的实际设计和实现,提高学生的动手实践能力。
4.讨论法:在课堂上鼓励学生积极参与讨论,培养学生的思维能力和团队协作能力。
四、教学资源为了支持本节课的教学内容和教学方法的实施,我们将准备以下教学资源:1.教材:选用合适的Java编程教材,为学生提供基础知识的支持。
2.多媒体资料:制作课件、演示文稿等多媒体资料,帮助学生更好地理解和掌握知识。
3.实验设备:准备计算机、网络设备等实验设备,为学生提供实践操作的机会。
Java图书管理系统课程设计报告

湖南科技学院2012年 6月目录课题说明 (3)程序设计思路 (4)程序状态转换图 (4)数据库设计 (5)程序部分源代码 (6)Login.java登录类 (6)QueryBook.java 查找修改书籍类 (10)BookIn.java图书入库类 (17)RemoveBook.java 图书删除类 (22)Book.java 主界面类 (29)ConnectMysql.java数据库连接类 (33)程序测试 (34)登录 (34)主界面 (34)图书查询修改界面 (35)图书入库界面 (36)图书删除界面 (37)图书概览界面 (37)修改密码界面 (38)学生信息查询界面 (38)设计总结 (39)前期准备 (39)编程实现 (39)经验体会 (39)参考文献 (40)课题说明1、设计一个图书信息管理系统2、图书信息包括图书编号、书名、作者、出版社、出版日期、图书简介及图书类别等。
3、本系统功能描述:图书信息录入功能;图书信息浏览功能;查询功能(至少一种查询方式);图书信息修改功能;及其它你认为必要的功能。
程序设计思路程序较小,分为七个个模块,分别实现:登录,图书查询修改,图书入库,图书修改,图书概览,修改密码,学生信息查询。
程序通过登录模块登录后可以通过点击相应按钮使用其余六个模块的功能,从而实现图书管理员。
程序状态转换图Login.java通过ConnectMysql.连java接数据库登录取消确定,修改QueryBook.java 借书者信息StudenInfo.java通过通过ConnectMysql.java取消ConnectMysql.java 连接数据tpl库登录系统连接数据tpl库打开图书查询修改界打开学生查询界面面图书查询修改确定,修改学生信息查询修改确定,取消BookIn.java Login.java UpdateMima.java 通过通过通过ConnectMysql.java 图书入库ConnectMysql.java修改密码ConnectMysql.java连接数据tpl库连接数据tpl库连接数据tpl库打开图书入库界面打开程序主界面打开修改密码界面确定,取消借阅图书删除RemoveBook.java BookBrower.java通过图书概览通过ConnectMysql.java ConnectMysql.java连接数据tpl库连接数据tpl库打开图书删除界面取消打开图书概览界面查询,删除确定,返回数据库设计数据库类型为 MySQL Server 5.5数据库名称为 tpl下图为表结构程序部分源代码由于源代码较多,故只写出部分源代码Login.java登录类import java.awt.event.*;import javax.swing.*;import java.awt.*;import java.sql.*;@SuppressWarnings ( "serial" )class Login extends JFrame implements ActionListener// 登录窗口类{ // 定义各容器和组件Container cp=null ;JFrame f =null ;JButton j1 , j2 ;JTextField t1 ;JPasswordField t2 ;JLabel jlable1 , jlable2 ;Color c;JPanel jp1 , jp2 ;//构造函数Login(){//创建各对象f =new JFrame( " 小型图书管理系统 " );j1=new JButton("确定");j2=new JButton("取消");cp =f .getContentPane();jlable1 =new JLabel( "输入用户名" );jlable2 =new JLabel( "用户密码" );// 重构 painComponent 函数实现 JPanel 添加背景jp1 =new JPanel(){public void paintComponent(Graphics g) {super .paintComponent(g);ImageIcon img =new ImageIcon( "1.jpg" );g.drawImage(img.getImage(), 0, 0,null );}};jp2 =new JPanel();t1 =new JTextField(18);t2 =new JPasswordField(18);//将各组件加入相应的容器jp1 .add( jlable1 );jp1 .add( t1 );jp1 .add( jlable2 );jp1 .add( t2 );JLabel JL=new JLabel( " 欢迎登陆 " ,SwingConstants.CENTER);cp.add(JL, "North" );jp2 .add( j1 );jp2 .add( j2 );cp.add( jp1 , "Center" );cp.add( "South" , jp2 );jp1 .setBackground(new Color(255,153,255));Toolkit kit=Toolkit.getDefaultToolkit();Dimension screen=kit.getScreenSize();int x=screen. width ;/* 取得显示器窗口的宽度*/int y=screen. height ;/* 取得显示器窗口的高度*///setSize(x,y); /*让系统窗口平铺整个显示器窗口*/f .setSize(300,300);int xcenter=(x-300)/2;int ycenter=(y-300)/2;f .setLocation(xcenter,ycenter);/* 显示在窗口中央*/f .setVisible(true );//-----------------------------------------------------j1 .addActionListener(this ); // 注册事件监听器j2 .addActionListener(this );f .addWindowListener(new WindowAdapter(){//关闭窗口函数public void windowClosing(WindowEvent e){System.exit (0);}});}@SuppressWarnings ( "deprecation" )public void confirm() // 验证用户和密码是否存在{try { ConnectMysql a=new ConnectMysql();Connection con=a.Connecting();Statement sql=con.createStatement();String uName=t1 .getText().trim();String password=t2 .getText().trim();String queryMima="select * from user where用户名='" +uName+"' and密码='" +password+ "'" ;ResultSet rs=sql.executeQuery(queryMima);if (rs.next()){new Book(uName);f.hide();con.close();}else {JOptionPane.showMessageDialog( null , "该用户不存在" , " 提示! " ,JOptionPane.YES_NO_OPTION);}t1.setText("");t2.setText("");}catch (SQLException g){System.out .println("E Code" +g.getErrorCode());System.out .println("E M" +g.getMessage());}}//响应监听的不同事件public void actionPerformed(ActionEvent e){String cmd=e.getActionCommand();if (cmd.equals(" 确定 " )){confirm();}else if (cmd.equals(" 取消 " )){f .dispose();}}@SuppressWarnings ( "unused" )public static void main(String []arg){Login a=new Login();}}QueryBook.java 查找修改书籍类import java.awt.event.*;import javax.swing.*;import java.awt.*;import java.sql.*;class QueryBook implements ActionListener// 查询修改书籍信息窗口类{//定义容器和组件JFrame f3 ;Container cp;JPanel jp1 , jp2 , jp3 , jp4 , jp , jpanelWest ;JButton jbt1 , jbt2 , jbt3 , jbt4 ; // 按钮,确定、取消、修改、借书者信息JLabel label ;// 标签:请输入图书号JTextField tf , tf1 , tf2 , tf3 , tf4 , tf5 , tf6 , tf7 , tf8 ;// 定义文本框JLabel label1 , label2 , label3 , label4 ;QueryBook(){f3 =new JFrame();cp=f3 .getContentPane();//初始化面板、按钮、标签、文本框jp1 =new JPanel();jp2 =new JPanel();jp3 =new JPanel();jp4 =new JPanel();jpanelWest=new JPanel();jp =new JPanel();//------------------------------------------------jbt1=new JButton("确定");jbt2=new JButton("取消");jbt3=new JButton("修改");jbt4=new JButton(" 借书者信息 " );label=new JLabel(" 请输入图书号: " ,SwingConstants. CENTER); label.setForeground(Color.blue );tf=new JTextField(20);tf1=new JTextField(20);tf2=new JTextField(20);tf3=new JTextField(20);tf4=new JTextField(20);tf5=new JTextField(20);tf6=new JTextField(20);tf7=new JTextField(20);tf8=new JTextField(20);//布局 , 添加控件JPanel jpanel=new JPanel();jpanel.add(label);jpanel.add(tf );JPanel pp4=new JPanel();JPanel jpane4=new JPanel();cp.add(jpanel,"North" );JPanel pp2=new JPanel(new GridLayout(8,1));JPanel pp3=new JPanel();pp4.setLayout(new GridLayout(8,1));pp4.add(new JLabel(" 图书名 " ,SwingConstants.CENTER)); pp2.add(tf1);pp4.add(new JLabel(" 图书号 " ,SwingConstants.CENTER)); pp2.add(tf2);pp4.add(new JLabel(" 单价 " ,SwingConstants.));CENTERpp2.add(tf3);pp4.add(new JLabel(" 作者 " ,SwingConstants.CENTER)); pp2.add(tf4);pp4.add(new JLabel(" 出版社 " ,SwingConstants.));CENTERpp2.add(tf5);pp4.add(new JLabel(" 入库时间 " ,SwingConstants.CENTER)); pp2.add(tf6);pp4.add(new JLabel(" 是否被借 " ,SwingConstants.CENTER)); pp2.add(tf7);pp4.add(new JLabel(" 借书者学号 " ,SwingConstants.));CENTER pp2.add( tf8 );//将按钮加入 pp3中pp3.add( jbt1 ); // 按钮确定pp3.add( jbt2 ); // 按钮取消pp3.add( jbt3 ); // 按钮修改pp3.add( jbt4 ); // 按钮借书者信息cp.add(pp4, "West" );cp.add(pp2, "Center" );cp.add(pp3, "South" );cp.add(jpane4, "East" );//------------------------------------------------Toolkit kit=Toolkit.getDefaultToolkit();Dimension screen=kit.getScreenSize();int x=screen. width ;/* 取得显示器窗口的宽度*/int y=screen. height ;/* 取得显示器窗口的高度*/f3 .setSize(350,330);int xcenter=(x-350)/2;int ycenter=(y-330)/2;f3 .setLocation(xcenter,ycenter);/* 显示在窗口中央*/f3 .setVisible(true );//-------------------------------------------------jbt1 .addActionListener(this ); // 注册监听器jbt2 .addActionListener(this );jbt3 .addActionListener(this );jbt4 .addActionListener(this );}//------------------------------------------------public void showRecord(){try { ConnectMysql a=new ConnectMysql();Connection con=a.Connecting();Statement sql;String ql=tf .getText().trim();String s="select * from book where图书号='"+ql + "'" ;sql=con.createStatement();ResultSet rs=sql.executeQuery(s);if (rs.next()){String bname=rs.getString(1);String bno=rs.getString(2);String price=rs.getString(3);String writer=rs.getString(4);String publish=rs.getString(5);String indate=rs.getString(6);String isBorrowed=rs.getString(7);String borrowedName=rs.getString(8);tf1 .setText(bname);tf2 .setText(bno);tf3 .setText(price);tf4 .setText(writer);tf5 .setText(publish);tf6 .setText(indate);tf7 .setText(isBorrowed);tf8 .setText(borrowedName);}else{JOptionPane.showMessageDialog( null , "您输入的图书号不存在,请重新输入" , " 输入错误 " , JOptionPane.YES_NO_OPTION);}con.close();}catch (SQLException g){System.out .println("E Code" +g.getErrorCode());System.out .println("E M" +g.getMessage());}tf1.setEditable(true);tf2.setEditable(true);tf3.setEditable(true);tf4.setEditable(true);tf5.setEditable(true);tf6.setEditable(true);tf7.setEditable(true);tf8.setEditable(true);}public void fixRecord(){try { ConnectMysql a=new ConnectMysql();Connection con=a.Connecting();Statement sql;String s="update book set图书名='" +tf1 .getText()+"',图书号='" +tf2 .getText()+"',单价 ='" +tf3 .getText()+ "', 作者 ='" +tf4 .getText()+ "', 出版社 ='" +tf5 .getText()+ "', 入库时间='"+tf6 .getText()+ "', 是否被借 ='" +tf7 .getText()+ "', 借书者学号 ='" +tf8 .getText()+ "' where 图书号 ='"+tf2 .getText()+ "'" ;sql=con.createStatement();int fix=sql.executeUpdate(s);if (fix==1){JOptionPane.showMessageDialog( null , "修改成功!" ," 信息 " , RMATION_MESSAGE);}con.close();}catch (SQLException g){System.out .println("E Code" +g.getErrorCode());System.out .println("E M" +g.getMessage());}}public void ShowStuRecord(){StudentInfo Info=new StudentInfo();Info. tf .setText( tf8 .getText());Info.showRecord();}@SuppressWarnings ( "deprecation" ) public void actionPerformed(ActionEvent e){String cmd=e.getActionCommand();if (cmd.equals(" 确定 " )){showRecord();tf .setText( "" );}if (cmd.equals(" 修改 " )){fixRecord();}if (cmd.equals( " 借书者信息" )){ShowStuRecord();}if (cmd.equals(" 取消 " ))f3 .hide();}@SuppressWarnings ( "unused" )public static void main(String []arg){ QueryBook a=new QueryBook();}}BookIn.java图书入库类import java.awt.event.*;import javax.swing.*;import java.awt.*;import java.sql.*;//extends JFrameclass BookIn implements ActionListener// 图书入库类{JFrame f3 ;Container cp;JPanel jp1 , jp2 , jp3, jp4 , jp , jpanelWest ;JButton jbt1, jbt2; // 按钮 : 确定、取消、JLabel label;//标签JTextField tf1, tf2, tf3 , tf4 , tf5 , tf6 , tf7 , tf8 ;// 定义文本框JLabel label1 , label2 , label3 , label4 ;String sno;BookIn(){f3 =new JFrame();cp=f3 .getContentPane();//初始化面板、按钮、标签、文本框jp1 =new JPanel();jp2 =new JPanel();jp3 =new JPanel();jp4 =new JPanel();jpanelWest=new JPanel();jp =new JPanel();//------------------------------------------------jbt1 =new JButton(" 确定 " );jbt2 =new JButton(" 取消 " );//------------------------------------------------label =new JLabel( " 图书入库 " ,SwingConstants.CENTER); label .setForeground(Color.blue );//------------------------------------------------tf1 =new JTextField(20);tf2 =new JTextField(20);tf3 =new JTextField(20);tf4 =new JTextField(20);tf5 =new JTextField(20);tf6 =new JTextField(20);tf7 =new JTextField(20);tf8 =new JTextField(20);//------------------------------------------------//布局 , 添加控件jp1 .add( jbt1 );jp1 .add( jbt2 );sno =tf4 .getText();jp1 .add( new JLabel( " 您好 " +sno+" 欢迎登陆学生信息系统" )); JPanel jpanel=new JPanel();jpanel.add( label );JPanel pp4=new JPanel();JPanel jpane4=new JPanel();cp.add(jpanel,"North" );JPanel pp2= new JPanel(new GridLayout(8,1));JPanel pp3=new JPanel();pp4.setLayout(new GridLayout(8,1));pp4.add( new JLabel( " 图书名 " ,SwingConstants.CENTER));pp2.add(tf1);pp4.add(new JLabel(" 图书号 " ,SwingConstants.CENTER));pp2.add(tf2);pp4.add(new JLabel(" 单价 " ,SwingConstants.));CENTERpp2.add(tf3);pp4.add(new JLabel(" 作者 " ,SwingConstants.CENTER));pp2.add(tf4);pp4.add( new JLabel( " 出版社 " ,SwingConstants.CENTER));pp2.add( tf5 );pp4.add( new JLabel( " 入库时间 " ,SwingConstants.CENTER)); pp2.add( tf6 );pp4.add( new JLabel( " 是否被借 " ,SwingConstants.CENTER)); pp2.add( tf7 );pp4.add( new JLabel( " 借书者学号 " ,SwingConstants.CENTER)); pp2.add( tf8 );pp3.add( jbt1 );pp3.add( jbt2 );cp .add(pp4, "West" );cp .add(pp2, "Center" );cp .add(pp3, "South" );cp .add(jpane4, "East" );//------------------------------------------------Toolkit kit=Toolkit.getDefaultToolkit();Dimension screen=kit.getScreenSize();int x=screen. width ;/* 取得显示器窗口的宽度*/int y=screen. height ;/* 取得显示器窗口的高度*/f3 .setSize(350,330);int xcenter=(x-350)/2;int ycenter=(y-330)/2;f3.setLocation(xcenter,ycenter);/* 显示在窗口中央 */f3.setVisible(true );//-------------------------------------------------jbt1.addActionListener(this);// 注册监听器jbt2.addActionListener(this);}//------------------------------------------------public void insertRecord(){if ( tf1 .getText().equals("" )|| tf2 .getText().equals("" )|| tf3 .getText().equals("" )|| tf4 .getText().equals("" )|| tf5 .getText().equals("" )|| tf6 .getText().equals("" )) {JOptionPane.showMessageDialog( f3 , "请填写图书资料" );return ;}try { ConnectMysql a=new ConnectMysql();Connection con=a.Connecting();Statement sql;String s="insert into book values('"+tf1 .getText()+ "','"+tf2 .getText()+ "','"+ tf3 .getText()+ "','" +tf4 .getText()+ "','" +tf5 .getText()+ "','" +tf6 .getText()+ "','" +tf7 .getText()+ "','"//查询输入的图书号是否在数据库中存在String query="select * from book where图书号='" +tf2 .getText()+"'" ; sql=con.createStatement();ResultSet rs=sql.executeQuery(query);// 返回查询结果集boolean moreRecords=rs.next();// 判断结果集是否有数据if (moreRecords){JOptionPane.showMessageDialog( f3 , "图书号已经被使用,请重新输入" ); con.close();tf2 .setText( "" );return ;}int insert=sql.executeUpdate(s);if (insert==1){JOptionPane.showMessageDialog( null , "图书信息录入成功!" );tf1.setText("");tf2.setText("");tf3.setText("");tf4.setText("");tf5.setText("");tf6.setText("");tf7.setText("");tf8.setText("");}}catch(SQLException g){System.out .println("E Code" +g.getErrorCode());System.out .println("E M" +g.getMessage());}}@SuppressWarnings ( "deprecation")public void actionPerformed(ActionEvent e){String cmd=e.getActionCommand();if (cmd.equals(" 确定 " )){insertRecord();}else if (cmd.equals(" 取消 " ))f3 .hide();}@SuppressWarnings ( "unused" )public static void main(String []arg){BookIn a=new BookIn();}}RemoveBook.java 图书删除类import java.awt.event.*;import javax.swing.*;import java.awt.*;import java.sql.*;class RemoveBook implements ActionListener// 图书删除类{JFrame f ;Container cp;JPanel jpS , jpanelWest ;JButton jbt1 , jbt2 , jbt3 , jbt4 ; // 按钮,查询、取消、修改JLabel label , L;// 标签:请输入学号JTextField tf ;// 定义文本框JTable table ; // 用来接收数据库中返回的信息Object columnName[]={ " 图书名 " , " 图书号 " , " 单价 " , " 作者 " , " 出版社 " , " 入库时间 " , " 是否被借 " , "借书者学号"};Object ar [][] =new Object[80][8];String sno;String count ="xx" ;@SuppressWarnings ( "unused" )RemoveBook(){f =new JFrame();cp=f .getContentPane(); // 初始化面板、按钮、标签、文本框 jpS=new JPanel();jpanelWest=new JPanel();//------------------------------------------------jbt1=new JButton("查询");jbt2=new JButton("取消");jbt3=new JButton("删除");jbt4=new JButton("修改");//------------------------------------------------label =new JLabel( " 请输入要删除的图书名:" ,SwingConstants.CENTER);label .setForeground(Color.blue );L=new JLabel( " 该种图书共有" +count +" 本 " );//------------------------------------------------table =new JTable( ar , columnName); //ar存放表中的数据,columnname表示列名JScrollPane scrollpane =new JScrollPane(table );//------------------------------------------------tf =new JTextField(18);//------------------------------------------------//布局 , 添加控件jpS .add( jbt1 );jpS .add( jbt2 );jpS .add( jbt3 );jpS .add( jbt4 );JPanel jpanel=new JPanel();jpanel.add(label );jpanel.add(tf);JPanel pp4=new JPanel();JPanel jpE=new JPanel();cp.add(jpanel,"North" );JPanel jp=new JPanel();JPanel p= new JPanel(); // 用来放两个表p.setLayout(new BorderLayout());p.add( L, "North" );p.add(scrollpane);cp.add(pp4, "West" );cp.add(p, "Center" );cp.add( jpS , "South" );cp.add(jpE, "East" );//------------------------------------------------Toolkit kit=Toolkit.getDefaultToolkit(); Dimension screen=kit.getScreenSize();int x=screen. width ;/* 取得显示器窗口的宽度*/ int y=screen. height ;/* 取得显示器窗口的高度*/f .setSize(400,330);int xcenter=(x-350)/2;int ycenter=(y-330)/2;f .setLocation(xcenter,ycenter);/* 显示在窗口中央*/f .setVisible(true );//-------------------------------------------------jbt1.addActionListener(this); // 注册监听器jbt2.addActionListener(this);jbt3.addActionListener(this);jbt4.addActionListener(this);}int i=0;public void showRecord(String ql){while( i >=0){ar [i ][0]="";ar [i ][1]="";ar [i ][2]="";ar [i ][3]="";ar [i ][4]="";ar [i ][5]="";ar [i ][6]="";ar [i ][7]="";i--;}i =0;try{ ConnectMysql a= new ConnectMysql();Connection con=a.Connecting();Statement sql;String s="select * from book where图书名 ='" +ql+ "'" ;sql=con.createStatement();ResultSet rs=sql.executeQuery(s);while (rs.next()){String bname=rs.getString(1);String bno=rs.getString(2);String price=rs.getString(3);String writer=rs.getString(4);String publish=rs.getString(5);String indate=rs.getString(6);String isBorrowed=rs.getString(7);String borrowedName=rs.getString(8);ar [ i ][0]=bname;ar [ i ][1]=bno;ar [ i ][2]=price;ar [ i ][3]=writer;ar [ i ][4]=publish;ar [ i ][5]=indate;ar [ i ][6]=isBorrowed;ar [ i ][7]=borrowedName;i ++;}count ="" +i +"" ;L.setText( " 该种图书共有" +count +" 本 " );f .repaint();con.close();System.out .println(ar [0][1]);}catch (SQLException g){System.out .println("E Code" +g.getErrorCode());System.out .println("E M" +g.getMessage());}}public void deleteRecord( int index){try { ConnectMysql a=new ConnectMysql();Connection con=a.Connecting();Statement sql;String ql=(String)(ar [index][1]);String s="delete from book where图书号='" +ql+ "'" ;sql=con.createStatement();int del=sql.executeUpdate(s);if (del==1){JOptionPane.showMessageDialog( null , "删除成功!" ," 信息 " , JOptionPane.INFORMATION_MESSAGE);}con.close();f.repaint();}catch (SQLException g){System.out .println("E Code" +g.getErrorCode());System.out .println("E M" +g.getMessage());}}@SuppressWarnings ( "unused" )public void fixRecord( int index){try { ConnectMysql a=new ConnectMysql();Connection con=a.Connecting();Statement sql;String ql=(String)(ar [index][1]);String s="update book set图书名='" +(String)(ar [index][0])+"',图书号word 资料='"+(String)(ar [index][3])+"',出版社 ='" +(String)(ar [index][4])+"', 入库时间='"+(String)(ar [index][5])+"',是否被借 ='" +(String)(ar [index][6])+"',借书者学号='"+(String)(ar [index][7])+"' where图书号 ='" +(String)( ar [index][1])+"'" ;sql=con.createStatement();int fix=sql.executeUpdate(s);if (fix==1){JOptionPane.showMessageDialog( null , "修改成功!具体还没实现" ," 信息 " , JOptionPane.YES_NO_OPTION);}con.close();f.repaint();}catch (SQLException g){System.out .println("E Code" +g.getErrorCode());System.out .println("E M" +g.getMessage());}}@SuppressWarnings ({ "unused" , "deprecation"})public void actionPerformed(ActionEvent e){String remember="" ;String ql="" ;String cmd=e.getActionCommand();if (cmd.equals(" 查询 " )){ql=tf .getText().trim();remember=ql;showRecord(ql);}if (cmd.equals(" 删除 " )){int index= table .getSelectedRow();word 资料JOptionPane.showMessageDialog( null , "请选定要删除的表格行" ,"输入错误 " , JOptionPane. YES_NO_OPTION);else {deleteRecord(index);//showRecord(remember);}}if (cmd.equals(" 修改 " )){int index= table.getSelectedRow();if ( index==-1)JOptionPane.showMessageDialog( null , "请选定要删除的表格行" ,"输入错误 " , JOptionPane. YES_NO_OPTION);else {fixRecord(index);//showRecord(remember);}}if (cmd.equals(" 取消 " ))f .hide();}@SuppressWarnings ( "unused" )public static void main(String []arg){RemoveBook a=new RemoveBook();}}Book.java 主界面类/* 本类为用户界面*/import java.awt.*;import java.awt.event.*;import javax.swing.*;import javax.swing.border.*;@SuppressWarnings ( "serial")class Book extends JFrame implements ActionListener// 主窗口类{JButton QueryScore =new JButton( " 图书查询修改" );JButton putBook =new JButton(" 图书入库 " );JButton shanchu =new JButton(" 图书删除 " );JButton lookBook =new JButton(" 图书概览 " );JButton gaiMima =new JButton(" 修改密码 " );JButton StuSearch =new JButton(" 学生信息查询 " );JMenuBar mb = new JMenuBar();// 菜单栏JPanel jp =new JPanel(){public void paintComponent(Graphics g) {super .paintComponent(g);ImageIcon img =new ImageIcon( "dabeijing.jpg");g.drawImage(img.getImage(), 0, 0,null );}}; ; // 用来填放子模块, 设置背景图片Container cp=getContentPane();String username ;Book(){}@SuppressWarnings ( "unused" )Book(String username){this . username=username;mb.add( QueryScore );mb.add( putBook );mb.add( shanchu );mb.add( lookBook );mb.add( gaiMima );mb.add( StuSearch );cp .add( mb, "North" );//设置边框jp .setBorder(BorderFactory.createTitledBorder(BorderFactory .createLineBorder(Color.blue , 2),null ,TitledBorder.CENTER,TitledBorder.TOP));jp .setLayout(new BorderLayout());JLabel JL=new JLabel( " 欢迎登陆 " ,SwingConstants.CENTER);jp .add(JL, "North" );JLabel label2 =new JLabel( new ImageIcon( "2.jpg")); JScrollPane scrollpane=new JScrollPane( jp );cp .add(scrollpane);setTitle(" 欢迎登陆 " ); // 在此直接创建对象Toolkit kit=Toolkit.getDefaultToolkit();Dimension screen=kit.getScreenSize();int x=screen. width ;/* 取得显示器窗口的宽度*/int y=screen. height ;/* 取得显示器窗口的高度*///setSize(x,y); /*让系统窗口平铺整个显示器窗口*/setSize(600,600);int xcenter=(x-600)/2;int ycenter=(y-600)/2;setLocation(xcenter,ycenter);/* 显示在窗口中央*/setVisible(true );setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);//注册临听器QueryScore .addActionListener(this );putBook .addActionListener(this );shanchu .addActionListener(this );lookBook .addActionListener(this );gaiMima .addActionListener(this );StuSearch .addActionListener(this );}public void actionPerformed(ActionEvent e)// 状态转换{String cmd=e.getActionCommand();if (cmd.equals( " 图书查询修改" )){new QueryBook();}if (cmd.equals(" 图书入库 " )){new BookIn();}if (cmd.equals(" 图书删除 " )){new RemoveBook();}if (cmd.equals(" 图书概览 " )){new BookBrower().showRecord();}if (cmd.equals(" 修改密码 " )){new UpdateMima( username );}if (cmd.equals( " 学生信息查询" )){new StudentInfo();}}public static void main(String[]args){new Book( "" );}}ConnectMysql.java数据库连接类import java.sql.*;public class ConnectMysql { // 连接数据库类String url = "jdbc:mysql://localhost/tpl?user=root&password=789524613";/*** @paramargs* @throws SQLException*/public ConnectMysql(){this . url = "jdbc:mysql://localhost/tpl?user=root&password=789524613";}public Connection Connecting()throws SQLException{ // 连接数据库函数try {Class.forName( "com.mysql.jdbc.Driver");}catch (ClassNotFoundException e){System.out .println(" 加载驱动程序失败 !" );}String url ="jdbc:mysql://localhost/tpl?user=root&password=789524613"; // 直接使用当前类目录下的数据库文件return DriverManager.getConnection (url);}@SuppressWarnings ( "unused" )public static void main(String[] args) {//TODOAuto-generated method stubConnectMysql a=new ConnectMysql();}}程序测试登录主界面图书查询修改界面查询 000001 号书查询借书者信息,修改图书单价输入入库信息图书入库删除图书《图书管理》图书概览界面所有图书信息修改密码界面修改密码学生信息查询界面查询学号为200905002109 学生的信息设计总结前期准备开始程序编写前先将题目要求实现的功能理清,然后分析需求,设计出各个界面草图以及数据库表的结构。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
山东建筑大学课程设计说明书题目:图书管理系统课程: JAVA程序设计基础课程设计院(部):信息与电气工程学院专业:物联网工程班级:物联121学生姓名:***学号:032指导教师:**完成日期:2015年7月10日一摘要............................................ 错误!未定义书签。
二所需软件......................................... 错误!未定义书签。
三 E-R图与结构功能图............................... 错误!未定义书签。
E-R图...................................... 错误!未定义书签。
功能结构图.................................. 错误!未定义书签。
四所需表格......................................... 错误!未定义书签。
Sql创建语句................................ 错误!未定义书签。
五页面的结构和关系................................. 错误!未定义书签。
六程序截图......................................... 错误!未定义书签。
七总结............................................ 错误!未定义书签。
八参考文献......................................... 错误!未定义书签。
附录................................................ 错误!未定义书签。
(1)登录模块代码............................... 错误!未定义书签。
(2)图书管理模块代码........................... 错误!未定义书签。
一摘要设计一个小型图书管理系统,该系统由登录模块和功能模块组成。
登录模块实现管理员登录,功能模块分为图书查询、图书入库、图书删除、图书修改四个部分。
图书管理系统的开发主要涉及到用户登录和图书信息管理。
图书信息管理包括:添加新进图书、删除旧图书、修改图书信息、图书查询。
用户可以浏览、查询、添加、删除、修改图书的基本信息。
创建公共类,主要是用于连接数据库的操作,事件监听操作)创建主窗体及登陆窗体。
利用JFrame来JButton子类来进行设计创建所要应用的各功能内嵌面板,并实现相应数据库连接处理功能。
二所需软件操作系统:Windows数据库服务器:mySQLserver开发工具:eclipse3.4.1、JDBC驱动:mysql-connector-java-5.1.7-bin JAVA环境;jre-8u25-windows-i586三 E-R图与结构功能图E-R图功能结构图图1 图书管理系统功能结构图四所需表格根据系统分析,设计图书信息管理系统的数据库(book)表有:图2 SQL创建结果图用户信息表(表1)、图书信息表(表2)。
表结构如下:表1:user表2:bookSql创建语句Create database book;Use book;Create table user(id varchar(10) primary key,psw varchar(10)); Insert into user values(“xx”,123456);Create table book(bid varchar(10) primary key, bname varchar(10),wname varchar(10),num1 varchar(10),chubs varchar(10),num2 varchar(2));Insert into book values(1001,”JAVA”,”山建”,10,”山建出版社”,10);五页面的结构和关系六程序截图图3 登录界面图4 管理界面七总结从上面的演示中可以看出,此系统可以完成用户登录和图书管理两大功能。
在本系统的应用下可以实现用户按照书名查询书库的藏书,方便的增添图书,删除图书,修改图书信息。
测试阶段一方面发现了系统的各种错误,另外一方面验证了修改后的系统能够实现提高图书管理工作效率的预期目的。
不知不觉中,课程设计快接近尾声。
回顾这几天,短暂而充实。
也是由于时间比较紧张只有五天时间,所以该系统功能比较简单,暂且留待日后在完善。
最后感谢这几天来宫淑兰老师对我们孜孜不倦的教导以及对本程序实验效果的鼓励。
为我在以后的学习道路中增加了信心。
八参考文献[1] 张思民. Java语言程序设计. 计算机科学与技术,2012, 292-305[2]飞思科技产品研发中心. JAVA应用开发详解[M].电子工业出版社,:32-300[3] 赛奎春. JAVA工程应用与项目实践[M]. 机械工业出版社,:23-294[4] 耿祥义,张跃平. JAVA实用教程[M]. 清华大学出版社,附录(1)登录模块代码package Library;import class Login extends JFrame {private static final long serialVersionUID = 1L;private JLabel jlUsername;private JLabel jlPwd;private JTextField txtUsername; dd(imgLabel, new Integer);etOpaque(false); quals("id"))&&().equals("psw"))){new Book("管理界面");}else{(null, "您输入的账号或密码不正确");getTxtUsername().setText("");getTxtPassword().setText("");}}else{(null,"用户名不存在,请重新输入,错误!");getTxtUsername().setText("");getTxtPassword().setText("");}}catch(ClassNotFoundException e1){();} catch (SQLException e2) {1Ldd(imgLabel, new Integer);etOpaque(false); etText("");getBname().setText("");getWname().setText("");getNum1().setText("");getNum2().setText("");getCbs().setText("");}catch(ClassNotFoundException e){} catch (SQLException e) {etText("");}catch(ClassNotFoundException e){} catch (SQLException e) {etText("Bid"));getBname().setText("Bname"));getWname().setText("Wname"));getNum1().setText("num1"));getNum2().setText("num2"));getCbs().setText("chubs"));getjDel().setText("");}}catch(ClassNotFoundException e){} catch (SQLException e) {// TODO Auto-generated catch block();}finally { // 关闭Statementtry { ();} catch (Exception e) {}// 关闭Connectiontry { ();} catch (Exception e) {}}}});(new ActionListener(){public void actionPerformed(ActionEvent ee){String id1=();String name1=();String name2=();String n1=();String n2=();String chubs=();Connection conn=null;Statement stm=null;try{("");conn=("jdbc:","root","123");String sql="update set Bname='"+name1+"',Wname='"+name2+"',num1='"+n1+"',num2='"+n2+"',chubs='"+chu bs+"' where Bid='"+id1+"'";stm=();(sql);}catch(ClassNotFoundException e){} catch (SQLException e) {// TODO Auto-generated catch block();}finally { // 关闭Statementtry { ();} catch (Exception e) {}// 关闭Connectiontry { ();} catch (Exception e) {}}}});}}。