




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Java应用课程设计项目名称:小型图书管理系统课程名称:Java应用项目作者:* * *完成日期:2008年12月24日前言本系统是小型图书管理系统,专为个人设计。本系统启动后需要登陆,然后进入主界在这个界面我们可以选择所需要的功能模块来完成所要执行的功能。系统共有4个功能模块:图书入库、图书查询、图书删除、图书概览、修改密码。支持一系列关于图书管理方面的简单操作,诸如查询、删除、添加、修改密码等。系统流程图退出图书删除图书概览修改密码图书查询图书入库系统开始失败退出判断成功判断输入密码说明:首先是输入判断,相当于在登陆模块,要求用户输入用户名和密码;然后判断,如果判断失败退出系统,否则进入图
2、书管理系统的主界面。进入主界面后,用户要选择所需执行的功能,即通过鼠标点击相应项,来完成所需操作。图书名图书号单价作者出版社入库时间表book表user用户名密码数据库表 数据库设计在图书管理系统中,共设计2张表。本系统使用Access来创建数据表。数据库的名称为Book.mdb。1.表book字段名称数据类型图书名文本图书号文本(主键)单价文本作者文本出版社文本入库时间文本2.表user字段名称数据类型用户名文本(主键)密码文本系统源码程序代码1登陆界面:程序名Login.javaimport java.awt.event.*;import javax.swing.*;import java
3、.awt.*;import java.awt.Container;import java.util.*;import java.sql.*; 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("小型图书管理系统");j
4、1=new JButton("确定");j2=new JButton("取消");cp=f.getContentPane();jlable1=new JLabel(" 输入用户名");jlable2=new JLabel(" 用户密码"); jp1=new JPanel();jp2=new JPanel();t1=new JTextField(18);t2=new JPasswordField(18); jp1.add(jlable1); jp1.add(t1); jp1.add(jlable2);jp1.add(
5、t2); JLabel JL=new JLabel("<html><font color=#CC00FF size='7'><i>欢迎登陆</i></font>",SwingConstants.CENTER); cp.add(JL,"North");jp2.add(j1);jp2.add(j2); cp.add(jp1,"Center"); cp.add("South",jp2);jp1.setBackground(new Color(25
6、5,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.
7、setVisible(true); /- j1.addActionListener(this);/注册事件监听器 j2.addActionListener(this); f.addWindowListener(new WindowAdapter()public void windowClosing(WindowEvent e)System.exit(0);); public void confirm()/验证用户和密码是否存在 tryClass.forName("sun.jdbc.odbc.JdbcOdbcDriver"); catch(ClassNotFoundExcep
8、tion e)System.out.println("加载驱动程序失败!");tryString url = "jdbc:odbc:driver=Microsoft Access Driver (*.mdb);DBQ=Book.mdb"/直接使用当前类目录下的数据库文件Connection con=DriverManager.getConnection(url);Statement sql=con.createStatement();String uname=t1.getText().trim();String Mima=t2.getText().tri
9、m();String queryMima="select * from user where 用户名='"+uname+"' and 密码='"+Mima+"'"ResultSet rs=sql.executeQuery(queryMima); if(rs.next()new Book(uname);f.hide(); con.close(); elseJOptionPane.showMessageDialog(null,"该用户不存在","提示!", JOpti
10、onPane.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("确定&
11、quot;) confirm(); else if(cmd.equals("取消") f.dispose(); public static void main(String arg) Login a=new Login(); 2图书概览:程序名BookBrower.javaimport java.awt.event.*;import javax.swing.*;import java.awt.*;import java.awt.Container;import java.util.*;import java.sql.*;class BookBrower implements
12、 ActionListener JFrame f;Container cp;JPanel jpS,jpanelWest;JButton jbt1,jbt2;/按钮,查询、取消、修改JLabel label,L;/标签 /定义文本框JTable table;/用来接收数据库中返回的信息 Object columnName="图书名","图书号","单价","作者","出版社","入库时间" Object ar =new Object806;String sno;String c
13、ount="xx" BookBrower() f=new JFrame();cp=f.getContentPane(); / 初始化面板、按钮、标签、文本框jpS=new JPanel(); jpanelWest=new JPanel();/-jbt1=new JButton("确定"); jbt2=new JButton("返回"); /-label=new JLabel("<html><font color=#CC00FF size='4'>图书概览</font>&qu
14、ot;,SwingConstants.CENTER);label.setForeground(Color.blue);L=new JLabel("书库现在共有图书"+count+"本");/- table=new JTable(ar,columnName);/ar存放表中的数据,columnname表示列名JScrollPane scrollpane = new JScrollPane(table);/-/布局,添加控件jpS.add(jbt1);jpS.add(jbt2);JPanel jpanel=new JPanel();jpanel.add(la
15、bel);JPanel pp4=new JPanel(); JPanel jpE=new JPanel();cp.add(jpanel,"North");JPanel jp=new JPanel();/jp.add(scrollpane);JPanel p=new JPanel();/用来放两个表p.setLayout(new BorderLayout();p.add(L,"North");p.add(scrollpane); cp.add(pp4,"West");cp.add(p,"Center"); cp.ad
16、d(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);
17、/*显示在窗口中央*/ f.setVisible(true); /- jbt1.addActionListener(this);/注册监听器 jbt2.addActionListener(this); /* f.addWindowListener(new WindowAdapter()public void windowClosing(WindowEvent e)System.exit(0););*/-int i=0; public void showRecord() while(i>=0)ari0=""ari1=""ari2="&quo
18、t;ari3=""ari4=""ari5=""i-;i=0; tryClass.forName("sun.jdbc.odbc.JdbcOdbcDriver"); catch(ClassNotFoundException e)System.out.println("加载驱动程序失败!");try String url = "jdbc:odbc:driver=Microsoft Access Driver (*.mdb);DBQ=Book.mdb"/直接使用当前类目录下的数据库文
19、件 Connection con=DriverManager.getConnection(url); String s="select * from book " Statement 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
20、 publish=rs.getString(5);String indate=rs.getString(6);ari0=bname;ari1=bno;ari2=price;ari3=writer;ari4=publish;ari5=indate;i+; count=""+i+""L.setText("书库现在共有图书"+count+"本");f.repaint(); con.close(); catch(SQLException g) System.out.println("E Code"+g.
21、getErrorCode(); System.out.println("E M"+g.getMessage(); public void actionPerformed(ActionEvent e) String cmd=e.getActionCommand(); if(cmd.equals("确定") f.hide(); if(cmd.equals("返回") f.hide(); public static void main(String arg) BookBrower a=new BookBrower(); a.showReco
22、rd();3图书查询:程序名QueryBook.javaimport java.awt.event.*;import javax.swing.*;import java.awt.*;import java.awt.Container;import java.util.*;import java.sql.*;class QueryBook implements ActionListener JFrame f3;Container cp;JPanel jp1,jp2,jp3,jp4,jp,jpanelWest;JButton jbt1,jbt2;/按钮,确定、取消JLabel label;/标签:
23、请输入图书号JTextField tf,tf1,tf2,tf3,tf4,tf5,tf6; /定义文本框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("确定");
24、 jbt2=new JButton("取消");/-label=new JLabel("<html><font color=#CC00FF size='4'>请输入图书号:</font>",SwingConstants.CENTER);label.setForeground(Color.blue);tf=new JTextField(20); /-tf1=new JTextField(20);tf2=new JTextField(20);tf3=new JTextField(20);tf4=new JT
25、extField(20);tf5=new JTextField(20); tf6=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(6,1);JPanel pp3=new JPanel();pp4.setLayout(new G
26、ridLayout(6,1);pp4.add(new JLabel("图书名",SwingConstants.CENTER);pp2.add(tf1);pp4.add(new JLabel("图书号",SwingConstants.CENTER);pp2.add(tf2);pp4.add(new JLabel("单 价",SwingConstants.CENTER);pp2.add(tf3);pp4.add(new JLabel("作 者",SwingConstants.CENTER);pp2.add(tf4);p
27、p4.add(new JLabel("出版社",SwingConstants.CENTER);pp2.add(tf5);pp4.add(new JLabel("入库时间",SwingConstants.CENTER);pp2.add(tf6);pp3.add(jbt1); pp3.add(jbt2); cp.add(pp4,"West");cp.add(pp2,"Center"); cp.add(pp3,"South"); cp.add(jpane4,"East");/- T
28、oolkit 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
29、(this);/注册监听器 jbt2.addActionListener(this); /*f3.addWindowListener(new WindowAdapter()public void windowClosing(WindowEvent e)System.exit(0););*/-public void showRecord() tryClass.forName("sun.jdbc.odbc.JdbcOdbcDriver"); catch(ClassNotFoundException e)System.out.println("加载驱动程序失败!&quo
30、t;);tryString url = "jdbc:odbc:driver=Microsoft Access Driver (*.mdb);DBQ=Book.mdb"/直接使用当前类目录下的数据库文件Connection con=DriverManager.getConnection(url);Statement sql;String ql=tf.getText().trim();String s="select * from book where 图书号 ='"+ql +"'" sql=con.createState
31、ment(); 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);tf1.setText(bname);tf2.setText(bno);tf3.setText(price);tf4.setText(wr
32、iter);tf5.setText(publish);tf6.setText(indate); 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
33、(); tf1.setEditable(false); tf2.setEditable(false); tf3.setEditable(false); tf4.setEditable(false); tf5.setEditable(false); tf6.setEditable(false);public void actionPerformed(ActionEvent e) String cmd=e.getActionCommand(); if(cmd.equals("确定") showRecord();tf.setText(""); else if(
34、cmd.equals("取消") f3.hide(); public static void main(String arg) QueryBook a=new QueryBook();4图书删除:程序名RemoveBook.javaimport java.awt.event.*;import javax.swing.*;import java.awt.*;import java.awt.Container;import java.util.*;import java.sql.*;class RemoveBook implements ActionListener JFram
35、e f;Container cp;JPanel jpS,jpanelWest;JButton jbt1,jbt2,jbt3;/按钮,查询、取消、修改JLabel label,L;/标签:请输入学号JTextField tf; /定义文本框JTable table;/用来接收数据库中返回的信息 Object columnName="图书名","图书号","单价","作者","出版社","入库时间" Object ar =new Object806;String sno;Stri
36、ng count="xx" RemoveBook() f=new JFrame();cp=f.getContentPane(); / 初始化面板、按钮、标签、文本框jpS=new JPanel(); jpanelWest=new JPanel();/-jbt1=new JButton("查询"); jbt2=new JButton("取消"); jbt3=new JButton("删除");/-label=new JLabel("<html><font color=#CC00FF siz
37、e='4'>请输入要删除的图书名:</font>",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); /-/-/布局,添加控
38、件jpS.add(jbt1);jpS.add(jbt2);jpS.add(jbt3);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();/jp.add(scrollpane);JPanel p=new JPanel();/用来放两个表p.setLayout(new BorderLayout();p.add(L,&quo
39、t;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;/*取得显示器窗口的高度*/
40、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); /*f.addWindowListener(new WindowAdapter()public void windowClosing(Windo
41、wEvent e)System.exit(0););*/-int i=0; public void showRecord(String ql) while(i>=0)ari0=""ari1=""ari2=""ari3=""ari4=""ari5=""i-;i=0; tryClass.forName("sun.jdbc.odbc.JdbcOdbcDriver"); catch(ClassNotFoundException e)System.out.pr
42、intln("加载驱动程序失败!");try String url = "jdbc:odbc:driver=Microsoft Access Driver (*.mdb);DBQ=Book.mdb"/直接使用当前类目录下的数据库文件 Connection con=DriverManager.getConnection(url); Statement sql; String s="select * from book where 图书名 ='"+ql +"'" sql=con.createStatem
43、ent(); 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);ari0=bname;ari1=bno;ari2=price;ari3=writer;ari4=publish;ari5=indate
44、;i+; count=""+i+""L.setText("该种图书共有"+count+"本");f.repaint(); con.close();System.out.println(ar01); catch(SQLException g) System.out.println("E Code"+g.getErrorCode(); System.out.println("E M"+g.getMessage(); public void deleteRecord(int ind
45、ex) tryClass.forName("sun.jdbc.odbc.JdbcOdbcDriver"); catch(ClassNotFoundException e)System.out.println("加载驱动程序失败!");tryString url = "jdbc:odbc:driver=Microsoft Access Driver (*.mdb);DBQ=Book.mdb"/直接使用当前类目录下的数据库文件Connection con=DriverManager.getConnection(url);Statement
46、 sql;String ql=(String)(arindex1);String s="delete * from book where 图书号 ='"+ql +"'" sql=con.createStatement(); int del=sql.executeUpdate(s); if(del=1) JOptionPane.showMessageDialog(null,"删除成功!", "信息", JOptionPane.YES_NO_OPTION); con.close();f.repaint(
47、); catch(SQLException g)System.out.println("E Code"+g.getErrorCode();System.out.println("E M"+g.getMessage(); 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(); if( index=-1) JOptionPane.showMessageDialog(null,"请选定要删除的表格行", "输入错误", JOptionPane.YES_NO_OPTION); else deleteRecord
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025届安徽省庐江盛桥中学高考化学一模试卷含解析
- 2025年煤炭机械装备项目建议书
- 幼儿园教育活动的类型
- 中考数学高频考点专项练习:专题13 三角形综合训练 (2)及答案
- 2025年移动通信终端设备及零部件项目发展计划
- 2025届浙江省湖州市长兴县、德清县、安吉县高三最后一模化学试题含解析
- 嗮鱼干创意画课件
- 中医医院护理操作规范
- 2025年全麦面包项目合作计划书
- 2025届江苏省徐州市铜山中学高考化学必刷试卷含解析
- 国开2023秋《人文英语4》第1-4单元作文练习参考答案
- 无人机地形匹配导航
- 中医病历示例
- 新人教版高中英语必修第二册-Unit-5THE-VIRTUAL-CHOIR精美课件
- 第9章-无线Mesh网络要点课件
- 一身边的“雷锋”(课件)五年级下册综合实践活动
- 工程造价司法鉴定报告案例
- 广东判后答疑申请书
- 中科院考博生态学和自然地理学历年真题
- GB/T 42755-2023人工智能面向机器学习的数据标注规程
- 2022年秋季云南省普通高中学业水平考试地理试题( 含答案解析 )
评论
0/150
提交评论