版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、java 学生成绩管理系统代码import javax.swing.*;import java.awt.*;import java.awt.event.*;import java.sql.*;import javax.swing.*;import java.awt.*;import java.awt.event.*; import java.awt.event.*;import javax.swing.*;import java.awt.*;import java.awt.event.*;import java.sql.*;import javax.swing.table.JTableHead
2、er; import javax.swing.*;import java.awt.*;import java.awt.event.*;import java.sql.*;import javax.swing.*;import java.awt.*;import java.awt.event.*;import java.sql.*;import javax.swing.*;import java.awt.*;import java.awt.event.*;import java.sql.*;import javax.swing.*;import java.awt.*;import java.aw
3、t.event.*;import java.sql.*;import javax.swing.table.DefaultTableModel; importjavax.swing.table.JTableHeader; import javax.swing.*;import java.awt.*;import java.awt.event.*;import java.sql.*;class AddForm extends JFrame implements ActionListenerJLabel labName=new JLabel( 学号 :);JLabel labDate=new JLa
4、bel( 出生日期 :);JLabel labScore=new JLabel( 成绩 :);JTextField txtName=new JTextField(20);JTextField txtDate=new JTextField(18);JTextField txtScore=new JTextField(20);JButton btnOk=new JButton( 确定 );JButton btnClear=new JButton( 清空 );JPanel pan=new JPanel();JPanel pan1=new JPanel();JPanel pan2=new JPanel
5、();JPanel pan3=new JPanel();JPanel pan4=new JPanel();Connection cnn;Statement stm;ResultSet rs;AddForm()super( 添加数据 );setSize(400,300);setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);pan.setBorder(BorderFactory.createEtchedBorder();pan1.add(labName);pan1.add(txtName);pan2.add(labDate);pan2.add(txt
6、Date);pan3.add(labScore);pan3.add(txtScore);pan4.add(btnOk);pan4.add(btnClear);pan.setLayout(new GridLayout(3,1);pan.add(pan1);pan.add(pan2);pan.add(pan3);getContentPane().add(pan,Center);getContentPane().add(pan4,South);btnOk.addActionListener(this);btnClear.addActionListener(this);setVisible(true)
7、;txtName.requestFocus();public void actionPerformed(ActionEvent ae)if(ae.getSource()=btnClear)txtName.setText();txtDate.setText();txtScore.setText();txtName.requestFocus();else if(ae.getSource()=btnOk)String strName=txtName.getText();String strDate=txtDate.getText();String strScore=txtScore.getText(
8、);if(strName.equals()JOptionPane.showMessageDialog(this,学号不能为空,警告,JOptionPane.ERROR_MESSAGE);else if(strDate.equals()JOptionPane.showMessageDialog(this, 警告,JOptionPane.ERROR_MESSAGE);else if(strScore.equals()JOptionPane.showMessageDialog(this,成绩不能为空,警告,JOptionPane.ERROR_MESSAGE);elsetry Class.forNam
9、e(sun.jdbc.odbc.JdbcOdbcDriver); catch (ClassNotFoundException ex) ex.printStackTrace();try cnn=DriverManager.getConnection(Jdbc:Odbc:MyDB);stm=cnn.createStatement(); catch (SQLException ex) ex.printStackTrace();tryrs = stm.executeQuery(select * from 成绩表 where 学号 = +strName + );if (rs.next() JOption
10、Pane.showMessageDialog(this,对不起,该成绩信息已存在”); else / 否则插入记录/System.out.println(insert into成绩表values(+strName+,#+strDate+#,+strScore+);stm.executeUpdate(insert into 成绩表values(+strName+,+strDate+,+strScore+);JOptionPane.showMessageDialog(null,”记录已经成功添加);/ 断开连接stm.close();cnn.close(); catch (SQLException
11、 ex) System.out.println(SQLException: + ex.getMessage();public static void main(String args) new AddForm();class BrowseForm extends JFrame String str= 学号 , 出生日期 , 成绩 ;Object data;JTable table;JTableHeader head;JScrollPane jsp;Connection conn;Statement stmt;ResultSet rs;BrowseForm()super( 浏览数据 );setS
12、ize(400,300);int i=0,j=0;int row;tryClass.forName(sun.jdbc.odbc.JdbcOdbcDriver);conn=DriverManager.getConnection(jdbc:odbc:MyDB,);stmt=conn.createStatement();rs=stmt.executeQuery(select COUNT(*) as a from 成绩表 );rs.next();row=rs.getInt(a);rs.close();data=new Objectrow3;rs=stmt.executeQuery(select * f
13、rom 成绩表 );while(rs.next()dataij+=rs.getString( 学号 );dataij+=rs.getDate( 出生日期 );dataij=new Integer(rs.getInt(成绩 );i+;j=0;table=new JTable(data,str);head=table.getTableHeader();jsp=new JScrollPane(table);getContentPane().add(head,North);getContentPane().add(jsp,Center);rs.close();stmt.close();conn.clo
14、se();catch(Exception e) e.printStackTrace();setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE); setVisible(true);public static void main(String args) new BrowseForm();class DeleteForm extends JFrame implements ActionListener JLabel labName=new JLabel( 学号 :);JLabel labDate=new JLabel( 出生日期 :);JLabel l
15、abScore=new JLabel( 成绩 :);JTextField txtName=new JTextField(20);JTextField txtDate=new JTextField(18);JTextField txtScore=new JTextField(20);JButton btnDel=new JButton( 删除 );JButton btnCancel=new JButton( 取消 );JButton btnQuery=new JButton( 查询 );JPanel pan=new JPanel();JPanel pan1=new JPanel();JPanel
16、 pan2=new JPanel();JPanel pan3=new JPanel();JPanel pan4=new JPanel();Connection cnn;Statement stm;ResultSet rs;DeleteForm()super( 删除数据 );setSize(400,300);setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);pan.setBorder(BorderFactory.createEtchedBorder();pan1.add(labName);pan1.add(txtName);pan2.add(la
17、bDate);pan2.add(txtDate);pan3.add(labScore);pan3.add(txtScore);pan4.add(btnQuery);pan4.add(btnDel);pan4.add(btnCancel);pan.setLayout(new GridLayout(3,1);pan.add(pan1);pan.add(pan2);pan.add(pan3);getContentPane().add(pan,Center);getContentPane().add(pan4,South);btnQuery.addActionListener(this);btnDel
18、.addActionListener(this);btnCancel.addActionListener(this);btnDel.setEnabled(false);txtDate.setEditable(false);txtScore.setEditable(false);setVisible(true);txtName.requestFocus();public void actionPerformed(ActionEvent ae)/* if(ae.getSource()=btnCancel)try if(stm!=null)stm.close();if(cnn!=null)cnn.c
19、lose(); catch (SQLException ex) ex.printStackTrace();this.dispose(); else if(ae.getSource()=btnQuery)tryClass.forName(sun.jdbc.odbc.JdbcOdbcDriver);cnn=DriverManager.getConnection(jdbc:odbc:MyDB,);stm=cnn.createStatement();rs=stm.executeQuery(select * from 成绩表 where 学号=+txtName.getText()+);if(rs.nex
20、t()txtName.setText(rs.getString( 学号 );txtDate.setText(rs.getDate( 出生日期 ).toString();txtScore.setText(new Integer(rs.getInt( 成绩 ).toString();btnDel.setEnabled(true);elseJOptionPane.showMessageDialog(this,不存在该记录);btnDel.setEnabled(false);txtName.setText();txtScore.setText();txtDate.setText();catch(Exc
21、eption e)e.printStackTrace();else if(ae.getSource()=btnDel)try if(JOptionPane.YES_OPTION=JOptionPane.showConfirmDialog(this, 确定要删除该记录, 信息 ,JOptionPane.YES_NO_OPTION)stm.executeUpdate(delete from 成绩表 where 学号=+txtName.getText()+);btnDel.setEnabled(false);txtName.setText();txtScore.setText();txtDate.s
22、etText();catch (SQLException ex) ex.printStackTrace();*/public static void main(String args) new DeleteForm();class LoginForm extends JFrame implements ActionListenerJLabel labName=new JLabel( 姓名 );JLabel labPwd=new JLabel( 密码 );JTextField txtName=new JTextField(20);JPasswordField txtPwd=new JPasswo
23、rdField(20);JButton btnOk=new JButton( 确定 );JButton btnCancel=new JButton( 取消 );JPanel pan=new JPanel();JPanel pan1=new JPanel();JPanel pan2=new JPanel();JPanel pan3=new JPanel();JPanel pan4=new JPanel();Connection cnn;Statement stm;ResultSet rs;LoginForm()super( 用户登录 );setSize(300,200);setDefaultCl
24、oseOperation(JFrame.DISPOSE_ON_CLOSE);pan.setBorder(BorderFactory.createTitledBorder( 登录 );pan.setLayout(new GridLayout(2,1);pan1.add(labName);pan1.add(txtName);pan2.add(labPwd);pan2.add(txtPwd);pan.add(pan1);pan.add(pan2);pan3.add(btnOk);pan3.add(btnCancel);pan4.add(pan);getContentPane().add(pan4,C
25、enter);getContentPane().add(pan3,South);txtName.addActionListener(this);txtPwd.addActionListener(this);btnOk.addActionListener(this);btnCancel.addActionListener(this);setVisible(true);try Class.forName(sun.jdbc.odbc.JdbcOdbcDriver); catch (ClassNotFoundException ex) ex.printStackTrace();try cnn=Driv
26、erManager.getConnection(Jdbc:Odbc:MyDB);stm=cnn.createStatement(); catch (SQLException ex) ex.printStackTrace();txtName.requestFocus();public void actionPerformed(ActionEvent ae)if(ae.getSource()=txtName)txtPwd.requestFocus();else if(ae.getSource()=txtPwd)btnOk.requestFocus();else if(ae.getSource()=
27、btnCancel)txtName.setText();txtPwd.setText();txtName.requestFocus();else if(ae.getSource()=btnOk)String str=select * from 用户表 where 用户名=+txtName.getText()+and 密码 =+new String(txtPwd.getPassword()+; try rs=stm.executeQuery(str); catch (SQLException ex) ex.printStackTrace();try if(rs.next()JOptionPane
28、.showMessageDialog(this, 验证通过 !, 信息,JOptionPane.INFORMATION_MESSAGE);rs.close();stm.close();cnn.close();new MainForm().setVisible(true);this.dispose();elseJOptionPane.showMessageDialog(this, 用户名或密码不正确!, 信息,JOptionPane.INFORMATION_MESSAGE); catch (SQLException ex) ex.printStackTrace();public static v
29、oid main(String args) new LoginForm();class ModifyForm extends JFrame implements ActionListenerJLabel labName=new JLabel( 学号 :);JLabel labDate=new JLabel( 出生日期 :);JLabel labScore=new JLabel( 成绩 :);JTextField txtName=new JTextField(20);JTextField txtDate=new JTextField(18);JTextField txtScore=new JTe
30、xtField(20);JButton btnModify=new JButton(修改 );JButton btnCancel=new JButton(取消 );JButton btnQuery=new JButton( 查询 );JPanel pan=new JPanel();JPanel pan1=new JPanel();JPanel pan2=new JPanel();JPanel pan3=new JPanel();JPanel pan4=new JPanel();Connection cnn;Statement stm;ResultSet rs;ModifyForm()super
31、( 修改数据 );setSize(400,300);setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);pan.setBorder(BorderFactory.createEtchedBorder();pan1.add(labName);pan1.add(txtName);pan2.add(labDate);pan2.add(txtDate);pan3.add(labScore);pan3.add(txtScore);pan4.add(btnQuery);pan4.add(btnModify);pan4.add(btnCancel);pan.se
32、tLayout(new GridLayout(3,1);pan.add(pan1);pan.add(pan2);pan.add(pan3);getContentPane().add(pan,Center);getContentPane().add(pan4,South);btnQuery.addActionListener(this);btnModify.addActionListener(this);btnCancel.addActionListener(this);btnModify.setEnabled(false);txtDate.setEditable(false);txtScore
33、.setEditable(false);setVisible(true);txtName.requestFocus();public void actionPerformed(ActionEvent ae)if(ae.getSource()=btnCancel)try if(stm!=null)stm.close();if(cnn!=null)cnn.close(); catch (SQLException ex) ex.printStackTrace();this.dispose(); else if(ae.getSource()=btnQuery)tryClass.forName(sun.
34、jdbc.odbc.JdbcOdbcDriver);cnn=DriverManager.getConnection(jdbc:odbc:MyDB,);stm=cnn.createStatement();rs=stm.executeQuery(select * from 成绩表 where 学号=+txtName.getText()+);if(rs.next()txtName.setText(rs.getString( 学号 );txtScore.setText(new Integer(rs.getInt( 成绩 ).toString();txtDate.setText(rs.getDate(
35、出生日期 ).toString();btnModify.setEnabled(true);txtDate.setEditable(true);txtScore.setEditable(true);elseJOptionPane.showMessageDialog(this,不存在该记录);btnModify.setEnabled(false);txtName.setText();txtScore.setText();txtDate.setText();txtDate.setEditable(false);txtScore.setEditable(false);catch(Exception e
36、)e.printStackTrace();else if(ae.getSource()=btnModify)trySystem.out.println(Update 成绩表 set 出生日期=#+txtDate.getText()+#, 成绩 =+txtScore.getText()+ where 学号=+txtName.getText()+);stm.executeUpdate(Update 成绩表 set 出生日期=#+txtDate.getText()+#, 成绩 =+txtScore.getText()+ where 学号=+txtName.getText()+);JOptionPan
37、e.showMessageDialog(this,”记录修改完毕”);btnModify.setEnabled(false);txtName.setText();txtScore.setText();txtDate.setText();txtDate.setEditable(false);txtScore.setEditable(false);stm.close();cnn.close();catch(Exception e)e.printStackTrace();public static void main(String args) new ModifyForm();class Numbe
38、rQueryForm extends JFrame implements ActionListenerJLabel labName=new JLabel( 学号 :);JLabel labDate=new JLabel( 出生日期 :);JLabel labScore=new JLabel( 成绩 :);JTextField txtName=new JTextField(20);JTextField txtDate=new JTextField(18);JTextField txtScore=new JTextField(20);JButton btnCancel=new JButton( 取
39、消 );JButton btnQuery=new JButton( 查询 );JPanel pan=new JPanel();JPanel pan1=new JPanel();JPanel pan2=new JPanel();JPanel pan3=new JPanel();JPanel pan4=new JPanel();Connection cnn;Statement stm;ResultSet rs;NumberQueryForm()super( 按学号查询 );setSize(400,300);setDefaultCloseOperation(JFrame.DISPOSE_ON_CLO
40、SE);pan.setBorder(BorderFactory.createEtchedBorder();pan1.add(labName);pan1.add(txtName);pan2.add(labDate);pan2.add(txtDate);pan3.add(labScore);pan3.add(txtScore);pan4.add(btnQuery);pan4.add(btnCancel);pan.setLayout(new GridLayout(3,1);pan.add(pan1);pan.add(pan2);pan.add(pan3);getContentPane().add(p
41、an,Center);getContentPane().add(pan4,South);btnQuery.addActionListener(this);btnCancel.addActionListener(this);txtDate.setEditable(false);txtScore.setEditable(false);setVisible(true);txtName.requestFocus();public void actionPerformed(ActionEvent ae)if(ae.getSource()=btnCancel)try if(stm!=null)stm.cl
42、ose();if(cnn!=null)cnn.close(); catch (SQLException ex) ex.printStackTrace();this.dispose(); else if(ae.getSource()=btnQuery)tryClass.forName(sun.jdbc.odbc.JdbcOdbcDriver);cnn=DriverManager.getConnection(jdbc:odbc:MyDB,);stm=cnn.createStatement();rs=stm.executeQuery(select * from 成绩表 where 学号=+txtNa
43、me.getText()+);if(rs.next()txtName.setText(rs.getString( 学号 );txtScore.setText(new Integer(rs.getInt( 成绩 ).toString();txtDate.setText(rs.getDate( 出生日期 ).toString();elseJOptionPane.showMessageDialog(this,不存在该记录);txtName.setText();txtScore.setText();txtDate.setText();txtName.requestFocus();catch(Excep
44、tion e)e.printStackTrace();public static void main(String args) new NumberQueryForm();class ScoreQueryForm extends JFrame implements ActionListenerJLabel labScore=new JLabel( 请输入成绩 :);JTextField txtScore=new JTextField(10);JButton btnQuery=new JButton( 查询 );JPanel pan1=new JPanel();JPanel pan2=new J
45、Panel();String str= 学号 , 出生日期 , 成绩 ;Object data=new Object103;JTable table=new JTable(data,str);JTableHeader head=table.getTableHeader();JScrollPane jsp=new JScrollPane(table);Connection conn;Statement stmt;ResultSet rs;ScoreQueryForm()super( 按成绩查询 );setSize(400,300);pan1.add(labScore);pan1.add(txtS
46、core);pan1.add(btnQuery);getContentPane().add(pan1,North);table=new JTable(data,str);pan2.setLayout(new BorderLayout();head=table.getTableHeader();jsp=new JScrollPane(table);pan2.add(head,North);pan2.add(jsp,Center);getContentPane().add(pan2,Center);btnQuery.addActionListener(this);setDefaultCloseOp
47、eration(JFrame.DISPOSE_ON_CLOSE);setVisible(true);public void actionPerformed(ActionEvent ae)if(ae.getSource()=btnQuery)int i,j,row;tryClass.forName(sun.jdbc.odbc.JdbcOdbcDriver);conn=DriverManager.getConnection(jdbc:odbc:MyDB,);stmt=conn.createStatement();成绩表 wherers=stmt.executeQuery(select COUNT(
48、*) as rowcount from成绩 =+txtScore.getText();rs.next();row=rs.getInt(rowcount);rs.close();data=new Objectrow3;rs=stmt.executeQuery(select * from 成绩表 where 成绩=+txtScore.getText();i=0;j=0;while(rs.next()dataij+=rs.getString( 学号 );dataij+=rs.getDate( 出生日期 );dataij=new Integer(rs.getInt(成绩 );i+;j=0;pan2.r
49、emoveAll();getContentPane().remove(pan2);table=new JTable(data,str);pan2.setLayout(new BorderLayout();head=table.getTableHeader();jsp=new JScrollPane(table);pan2.add(head,North);pan2.add(jsp,Center);getContentPane().add(pan2,Center);this.validate();rs.close();stmt.close();conn.close();catch(Exceptio
50、n e)e.printStackTrace();public static void main(String args) new ScoreQueryForm();class MyPanel extends JPanelImage img=Toolkit.getDefaultToolkit().getImage(c:/a.jpg);public void paint(Graphics g)g.drawImage(img,0,0,this);class MainForm extends JFrame implements ActionListener JMenu mSystem=new JMenu(系统) JMenuItem mExit=new JMenuItem(
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年度云计算服务与订阅合同6篇
- 《小学英语教学设计》课件 第九章 小学英语教学媒体设计
- 阅读进阶之旅
- 2024年度三人合伙承包深海油气钻探工程协议书
- 2024小学生安全教育教案(细选)
- 2024年度人力资源服务合作与共享合同
- 《金属元素学生》课件
- 化脓性鼻窦炎的临床护理
- 2024年度工程建设项目沙子采购合同
- 2024年度二手电梯买卖安装维护合同2篇
- 工程设计-《工程勘察设计收费标准》(2002年修订本)-完整版
- MOOC 光学发展与人类文明-华南师范大学 中国大学慕课答案
- 《龟兔赛跑的故事》PPT课件.ppt
- 年开展干部全覆盖谈心谈话工作情况报告
- NRC2012营养标准(中文版)
- 宝鸡市某办公楼空调用制冷机房设计
- 能量机动理论和飞行包线图
- 六年级环境教育备课(青岛版)
- 【设计】课程设计—混凝土结构(电大)(精华版)
- 关于全市财源建设情况的调研报告
- 渐变简约舞蹈培训拉丁舞知识介绍动态ppt模板
评论
0/150
提交评论