博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JAVA入门到精通-第73讲-学生管理系统5-dao.sqlhelper
阅读量:7288 次
发布时间:2019-06-30

本文共 30662 字,大约阅读时间需要 102 分钟。

-Model2模式
如果数据模型会很多,怎么办?
1167156-20181130182001577-1174963623.png
处理业务逻辑的:Model层
后台又分为:处理业务逻辑和对数据库的操作DAO-data access object
-决定,再抽象一层出来:数据模型:BO
-类:SqlHelper:专门对数据库操作,不含业务逻辑:DAO
-界面层只认业务逻辑类的对象;业务逻辑层认SqlHelper类的对象;
-每一层的功能不一样;
--------------------------------------------------------------
-把对数据库的操作放在SqlHelper类:
1167156-20181130182002386-1286533475.png
-传sql,传数组
-把关闭的代码单独拿出来,写成一个函数;
1167156-20181130182002669-1879833770.png
1167156-20181130182003046-2042935993.png
1167156-20181130182003438-154735702.png
-查询数据库的操作
public ResultSet queryExectue(String sql)
1167156-20181130182003687-115360321.png
1167156-20181130182004020-1391566221.png
1167156-20181130182004587-1403575968.png
分层的好处:修改某一模块,不影响其他功能模块
-SqlHelper
更新
1167156-20181130182004929-1811984878.png
单态的:始终只有一个连接
1167156-20181130182005222-985130726.png
-查询
1167156-20181130182005599-282016684.png
查询过后,资源没有关闭
1167156-20181130182005834-1760481832.png
1167156-20181130182006128-923727873.png
1167156-20181130182006463-2126313143.png
1167156-20181130182006669-7786285.png
select *  from  stu  where 1=? ,用?
没有问号,注入比较麻烦
1167156-20181130182006864-1266575558.png
让他们都统一起来,又不想多写一个函数
不需要注入参数
public ResultSet queryExecute(String sql)
1167156-20181130182007118-599957921.png
1167156-20181130182007361-1702304741.png
把数据更新一遍
1167156-20181130182007695-478549013.png
1167156-20181130182008387-1671208875.png
1167156-20181130182009044-273546947.png
-SqlHelper
1167156-20181130182009355-988723932.png
1167156-20181130182009589-715398430.png
========================================

[JTable_Test3.java]源码

/** * 完成一个mini版本的学生管理系统(MODEL2-2模式) * 1、查询任务 * 2、添加功能 */ package com.student3; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.Vector; import javax.swing.*; import javax.swing.table.AbstractTableModel; public class JTable_Test3 extends JFrame implements ActionListener{ //定义组件 JPanel jp1,jp2; JLabel jl1; JButton jb1,jb2,jb3,jb4; JTable jt; JScrollPane jsp; JTextField jtf; StuModel sm; public static void main(String[] args) { try { // 将当前窗体外观设置为所在操作系统的外观 UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName()); } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (InstantiationException e) { e.printStackTrace(); } catch (IllegalAccessException e) { e.printStackTrace(); } catch (UnsupportedLookAndFeelException e) { e.printStackTrace(); } new JTable_Test3(); } //构造函数 public JTable_Test3(){ jp1=new JPanel(); jtf=new JTextField(10); jb1=new JButton("查询"); jb1.addActionListener(this); jl1=new JLabel("请输入名字"); //把各个空间加入列 jp1.add(jl1); jp1.add(jtf); jp1.add(jb1); jp2=new JPanel(); jb2=new JButton("添加"); jb2.addActionListener(this); jb3=new JButton("修改"); jb3.addActionListener(this); jb4=new JButton("删除"); jb4.addActionListener(this); //把各个按钮加入到jp2中 jp2.add(jb2); jp2.add(jb3); jp2.add(jb4); //创建一个数据模型对象 sm=new StuModel(); String []paras={"1"}; sm.queryStu("select * from stu where 1=?", paras); //初始化JTable jt=new JTable(sm); //初始化jsp JScrollPane jsp=new JScrollPane(jt); //把jsp放入到jframe this.add(jsp); this.add(jp1,"North"); this.add(jp2,"South"); this.setSize(400, 300); this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); this.setVisible(true); } @Override public void actionPerformed(ActionEvent e) { if(e.getSource()==jb1){ //因为把对表的数据封装到StuModel中,我们就可以比较简单的完成查询 String name=this.jtf.getText(); //写一个SQL语句 String sql="select * from stu where stuName=?"; String []paras={name}; //构建新的数据模型类,并更新 sm=new StuModel(); sm.queryStu(sql, paras); //更新JTable jt.setModel(sm); } //用户点击添加时 else if(e.getSource()==jb2){ StuAddDialog sa=new StuAddDialog(this, "添加学生", true); //重新再获得新的数据模型 //构建新的数据模型类,并更新 sm=new StuModel(); String []paras2={"1"}; sm.queryStu("select * from stu where 1=?", paras2); //更新JTable jt.setModel(sm); } //用户修改数据 else if(e.getSource()==jb3){ int rowNum=this.jt.getSelectedRow(); if(rowNum==-1){ //提示 JOptionPane.showMessageDialog(this, "请选择一行", "提示", JOptionPane.INFORMATION_MESSAGE); return; } //显示修改对话框 new StuUpdDialog(this,"修改学生信息",true,sm,rowNum); //更新数据模型 sm=new StuModel(); String []paras2={"1"}; sm.queryStu("select * from stu where 1=?", paras2); //更新JTable jt.setModel(sm); } //用户点击删除时,删除一条选中的数据 else if(e.getSource()==jb4){ //1、得到学生的ID号 //getSelectedRow会返回用户点中的行 //如果该用户一行都没有选择,就会返回-1 int rowNum=this.jt.getSelectedRow(); if(rowNum==-1){ //提示 JOptionPane.showMessageDialog(this, "请选择一行", "提示", JOptionPane.INFORMATION_MESSAGE); return; } //得到学生编号 String stuId=(String)sm.getValueAt(rowNum, 0); //创建一个sql语句 String sql="delete from stu where stuid=?"; String []paras={stuId}; StuModel temp=new StuModel(); if(temp.updStu(sql, paras)){ JOptionPane.showMessageDialog(this,"删除数据成功","删除数据提示",JOptionPane.INFORMATION_MESSAGE); }else{ JOptionPane.showMessageDialog(this,"删除数据失败","删除数据提示",JOptionPane.ERROR_MESSAGE); } //更新数据模型 sm=new StuModel(); String []paras2={"1"}; sm.queryStu("select * from stu where 1=?", paras2); //更新JTable jt.setModel(sm); } } }
168
 
1
/**
2
* 完成一个mini版本的学生管理系统(MODEL2-2模式)
3
* 1、查询任务
4
* 2、添加功能
5
*/
6
package com.student3;
7
 
8
import java.awt.event.ActionEvent;
9
import java.awt.event.ActionListener;
10
import java.sql.Connection;
11
import java.sql.DriverManager;
12
import java.sql.PreparedStatement;
13
import java.sql.ResultSet;
14
import java.sql.SQLException;
15
import java.util.Vector;
16
import javax.swing.*;
17
import javax.swing.table.AbstractTableModel;
18
 
19
public class JTable_Test3 extends JFrame implements ActionListener{
20
   //定义组件
21
   JPanel jp1,jp2;
22
   JLabel jl1;
23
   JButton jb1,jb2,jb3,jb4;
24
   JTable jt;
25
   JScrollPane jsp;
26
   JTextField jtf;
27
   StuModel sm;
28
 
29
   public static void main(String[] args) {
30
       try {
31
           // 将当前窗体外观设置为所在操作系统的外观
32
           UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
33
       } catch (ClassNotFoundException e) {
34
           e.printStackTrace();
35
       } catch (InstantiationException e) {
36
           e.printStackTrace();
37
       } catch (IllegalAccessException e) {
38
           e.printStackTrace();
39
       } catch (UnsupportedLookAndFeelException e) {
40
           e.printStackTrace();
41
       }
42
       new JTable_Test3();
43
   }
44
 
45
   //构造函数
46
   public JTable_Test3(){
47
       jp1=new JPanel();
48
       jtf=new JTextField(10);
49
       jb1=new JButton("查询");
50
       jb1.addActionListener(this);
51
       jl1=new JLabel("请输入名字");
52
     
53
       //把各个空间加入列
54
       jp1.add(jl1);
55
       jp1.add(jtf);
56
       jp1.add(jb1);
57
     
58
       jp2=new JPanel();
59
       jb2=new JButton("添加");
60
       jb2.addActionListener(this);
61
       jb3=new JButton("修改");
62
       jb3.addActionListener(this);
63
       jb4=new JButton("删除");
64
       jb4.addActionListener(this);
65
       //把各个按钮加入到jp2中
66
       jp2.add(jb2);
67
       jp2.add(jb3);
68
       jp2.add(jb4);
69
     
70
       //创建一个数据模型对象
71
       sm=new StuModel();
72
       String []paras={
"1"};
73
       sm.queryStu("select * from stu where 1=?", paras);
74
     
75
       //初始化JTable
76
       jt=new JTable(sm);
77
     
78
       //初始化jsp JScrollPane
79
       jsp=new JScrollPane(jt);
80
     
81
       //把jsp放入到jframe
82
       this.add(jsp);
83
       this.add(jp1,"North");
84
       this.add(jp2,"South");
85
     
86
       this.setSize(400, 300);
87
       this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
88
       this.setVisible(true);
89
   }
90
 
91
   @Override
92
   public void actionPerformed(ActionEvent e) {
93
       if(e.getSource()==jb1){
94
           //因为把对表的数据封装到StuModel中,我们就可以比较简单的完成查询
95
           String name=this.jtf.getText();
96
           //写一个SQL语句
97
           String sql="select * from stu where stuName=?";
98
           String []paras={
name};
99
           //构建新的数据模型类,并更新
100
           sm=new StuModel();
101
           sm.queryStu(sql, paras);
102
           //更新JTable
103
           jt.setModel(sm);
104
       }
105
       //用户点击添加时
106
       else if(e.getSource()==jb2){
107
           StuAddDialog sa=new StuAddDialog(this, "添加学生", true);
108
           //重新再获得新的数据模型
109
           //构建新的数据模型类,并更新
110
           sm=new StuModel();
111
           String []paras2={
"1"};
112
           sm.queryStu("select * from stu where 1=?", paras2);
113
           //更新JTable
114
           jt.setModel(sm);
115
       }
116
       //用户修改数据
117
       else if(e.getSource()==jb3){
118
           int rowNum=this.jt.getSelectedRow();
119
           if(rowNum==-1){
120
               //提示
121
               JOptionPane.showMessageDialog(this, "请选择一行", "提示", JOptionPane.INFORMATION_MESSAGE);
122
               return;
123
           }
124
         
125
           //显示修改对话框
126
           new StuUpdDialog(this,"修改学生信息",true,sm,rowNum);
127
         
128
           //更新数据模型
129
           sm=new StuModel();
130
           String []paras2={
"1"};
131
           sm.queryStu("select * from stu where 1=?", paras2);
132
           //更新JTable
133
           jt.setModel(sm);
134
       }
135
     
136
       //用户点击删除时,删除一条选中的数据
137
       else if(e.getSource()==jb4){
138
           //1、得到学生的ID号
139
           //getSelectedRow会返回用户点中的行
140
           //如果该用户一行都没有选择,就会返回-1
141
           int rowNum=this.jt.getSelectedRow();
142
           if(rowNum==-1){
143
               //提示
144
               JOptionPane.showMessageDialog(this, "请选择一行", "提示", JOptionPane.INFORMATION_MESSAGE);
145
               return;
146
           }
147
           //得到学生编号
148
           String stuId=(String)sm.getValueAt(rowNum, 0);
149
           //创建一个sql语句
150
           String sql="delete from stu where stuid=?";
151
           String []paras={
stuId};
152
           StuModel temp=new StuModel();
153
           if(temp.updStu(sql, paras)){
154
               JOptionPane.showMessageDialog(this,"删除数据成功","删除数据提示",JOptionPane.INFORMATION_MESSAGE);
155
           }else{
156
               JOptionPane.showMessageDialog(this,"删除数据失败","删除数据提示",JOptionPane.ERROR_MESSAGE);
157
           }
158
         
159
           //更新数据模型
160
           sm=new StuModel();
161
           String []paras2={
"1"};
162
           sm.queryStu("select * from stu where 1=?", paras2);
163
           //更新JTable
164
           jt.setModel(sm);
165
       }
166
   }
167
}
168
 

*******************************************************************************

[StuModel.java]源码

/** * 这是一个stu表的模型 * 可以把对student表的各种操作封装到该模型中 */ package com.student3; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.Vector; import javax.swing.JOptionPane; import javax.swing.table.AbstractTableModel; public class StuModel extends AbstractTableModel{ //rowData用来存放行数据、columnNames存放列名 Vector rowData,columnNames; //添加学生(增、删、改) public boolean updStu(String sql,String []paras){ //创建SqlHelper(如果程序并发性不考虑,可以把SqlHelper做成static) SqlHelper sqlHelper=new SqlHelper(); return sqlHelper.updExecute(sql, paras); } //查询的本质就是用来初始化 public void queryStu(String sql,String []paras){ SqlHelper sqlHelper=null; //中间 columnNames=new Vector<>(); //设置列名 columnNames.add("学号"); columnNames.add("名字"); columnNames.add("性别"); columnNames.add("年龄"); columnNames.add("籍贯"); columnNames.add("系别"); rowData=new Vector<>(); //rowData可以存放多行 try { sqlHelper=new SqlHelper(); ResultSet rs=sqlHelper.queryExectue(sql, paras); while(rs.next()){ Vector hang=new Vector(); hang.add(rs.getString(1)); hang.add(rs.getString(2)); hang.add(rs.getString(3)); hang.add(rs.getInt(4)); hang.add(rs.getString(5)); hang.add(rs.getString(6)); //加入rowData rowData.add(hang); } } catch (Exception e) { e.printStackTrace(); }finally{ sqlHelper.close(); } } //得到共有多少列 public int getColumnCount() { return this.columnNames.size(); } @Override public String getColumnName(int column) { return (String)this.columnNames.get(column); } //得到共有多少行 public int getRowCount() { return this.rowData.size(); } //得到某行某列的数据 public Object getValueAt(int rowIndex, int columnIndex) { return ((Vector)this.rowData.get(rowIndex)).get(columnIndex); } }
84
 
1
/**
2
* 这是一个stu表的模型
3
* 可以把对student表的各种操作封装到该模型中
4
*/
5
package com.student3;
6
 
7
import java.sql.Connection;
8
import java.sql.DriverManager;
9
import java.sql.PreparedStatement;
10
import java.sql.ResultSet;
11
import java.sql.SQLException;
12
import java.util.Vector;
13
import javax.swing.JOptionPane;
14
import javax.swing.table.AbstractTableModel;
15
 
16
public class StuModel extends AbstractTableModel{
17
   //rowData用来存放行数据、columnNames存放列名
18
   Vector rowData,columnNames;
19
 
20
   //添加学生(增、删、改)
21
   public boolean updStu(String sql,String []paras){
22
       //创建SqlHelper(如果程序并发性不考虑,可以把SqlHelper做成static)
23
       SqlHelper sqlHelper=new SqlHelper();
24
       return sqlHelper.updExecute(sql, paras);
25
   }
26
 
27
   //查询的本质就是用来初始化
28
   public void queryStu(String sql,String []paras){
29
       SqlHelper sqlHelper=null;
30
       //中间
31
       columnNames=new Vector<>();
32
       //设置列名
33
       columnNames.add("学号");
34
       columnNames.add("名字");
35
       columnNames.add("性别");
36
       columnNames.add("年龄");
37
       columnNames.add("籍贯");
38
       columnNames.add("系别");
39
     
40
       rowData=new Vector<>();
41
       //rowData可以存放多行
42
       try {
43
           sqlHelper=new SqlHelper();
44
           ResultSet rs=sqlHelper.queryExectue(sql, paras);
45
         
46
           while(rs.next()){
47
               Vector hang=new Vector();
48
               hang.add(rs.getString(1));
49
               hang.add(rs.getString(2));
50
               hang.add(rs.getString(3));
51
               hang.add(rs.getInt(4));
52
               hang.add(rs.getString(5));
53
               hang.add(rs.getString(6));
54
               //加入rowData
55
               rowData.add(hang);
56
           }
57
       } catch (Exception e) {
58
           e.printStackTrace();
59
       }finally{
60
           sqlHelper.close();
61
       }
62
   }
63
 
64
   //得到共有多少列
65
   public int getColumnCount() {
66
       return this.columnNames.size();
67
   }
68
 
69
   @Override
70
   public String getColumnName(int column) {
71
       return (String)this.columnNames.get(column);
72
   }
73
 
74
   //得到共有多少行
75
   public int getRowCount() {
76
       return this.rowData.size();
77
   }
78
 
79
   //得到某行某列的数据
80
   public Object getValueAt(int rowIndex, int columnIndex) {
81
       return ((Vector)this.rowData.get(rowIndex)).get(columnIndex);
82
   }
83
}
84
 

*******************************************************************************

[SqlHelper.java]源码

/** * 这是一个对数据库进行操作的类(SqlHelper) */ package com.student3; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import javax.swing.JOptionPane; public class SqlHelper { //定义操作数据库需要的组件 PreparedStatement ps=null; Connection ct=null; ResultSet rs=null; String sqlDriver="com.microsoft.sqlserver.jdbc.SQLServerDriver"; String url="jdbc:sqlserver://127.0.0.1:1433;databaseName=stussystem;user=sa;password=sa;"; public SqlHelper(){ try { //1、加载驱动 Class.forName(sqlDriver); //2、得到连接 ct=DriverManager.getConnection(url); } catch (Exception e) { e.printStackTrace(); } } //关闭数据库资源 public void close(){ try { if(rs!=null){ rs.close(); } if(ps!=null){ ps.close(); } if(ct!=null){ ct.close(); } } catch (SQLException e1) { e1.printStackTrace(); } } //写一个不需要注入的方法(由于数据量少,所以写了一个这个方法。一般都带有条件的注入) public ResultSet queryExectue(String sql){ try { //3、创建ps ps=ct.prepareStatement(sql); rs=ps.executeQuery(); } catch (Exception e) { e.printStackTrace(); }finally{ //关闭资源??? } return rs; } //对数据库的查询操作 public ResultSet queryExectue(String sql,String []paras){ try { //3、创建ps ps=ct.prepareStatement(sql); //给ps的问号赋值 for(int i=0;i<paras.length;i++){ ps.setString(i+1, paras[i]); } rs=ps.executeQuery(); } catch (Exception e) { e.printStackTrace(); }finally{ //关闭资源??? } return rs; } //把对数据库的增、删、改合在一起 public boolean updExecute(String sql,String []paras){ boolean b=true; try { //3、创建ps ps=ct.prepareStatement(sql); //给ps的问号赋值 for(int i=0;i<paras.length;i++){ ps.setString(i+1, paras[i]); } //4、执行操作 if(ps.executeUpdate()!=1){ b=false; } } catch (Exception e) { b=false; JOptionPane.showMessageDialog(null, "数据源错误或数据库用户名、密码错误", "数据库连接错误提示", JOptionPane.ERROR_MESSAGE); e.printStackTrace(); }finally{ this.close(); } return b; } }
106
 
1
/**
2
* 这是一个对数据库进行操作的类(SqlHelper)
3
*/
4
package com.student3;
5
 
6
import java.sql.Connection;
7
import java.sql.DriverManager;
8
import java.sql.PreparedStatement;
9
import java.sql.ResultSet;
10
import java.sql.SQLException;
11
import javax.swing.JOptionPane;
12
 
13
public class SqlHelper {
14
   //定义操作数据库需要的组件
15
   PreparedStatement ps=null;
16
   Connection ct=null;
17
   ResultSet rs=null;
18
   String sqlDriver="com.microsoft.sqlserver.jdbc.SQLServerDriver";
19
   String url="jdbc:sqlserver://127.0.0.1:1433;databaseName=stussystem;user=sa;password=sa;";
20
 
21
   public SqlHelper(){
22
       try {
23
           //1、加载驱动
24
           Class.forName(sqlDriver);
25
           //2、得到连接
26
           ct=DriverManager.getConnection(url);
27
       } catch (Exception e) {
28
           e.printStackTrace();
29
       }
30
   }
31
 
32
   //关闭数据库资源
33
   public void close(){
34
       try {
35
           if(rs!=null){
36
               rs.close();
37
           }
38
           if(ps!=null){
39
               ps.close();
40
           }
41
           if(ct!=null){
42
               ct.close();
43
           }
44
       } catch (SQLException e1) {
45
           e1.printStackTrace();
46
       }
47
   }
48
 
49
   //写一个不需要注入的方法(由于数据量少,所以写了一个这个方法。一般都带有条件的注入)
50
   public ResultSet queryExectue(String sql){
51
       try {
52
           //3、创建ps
53
           ps=ct.prepareStatement(sql);
54
           rs=ps.executeQuery();
55
       } catch (Exception e) {
56
           e.printStackTrace();
57
       }finally{
58
           //关闭资源???
59
       }
60
       return rs;
61
   }
62
 
63
   //对数据库的查询操作
64
   public ResultSet queryExectue(String sql,String []paras){
65
       try {
66
           //3、创建ps
67
           ps=ct.prepareStatement(sql);
68
           //给ps的问号赋值
69
           for(int i=0;i
70
               ps.setString(i+1, paras[i]);
71
           }
72
         
73
           rs=ps.executeQuery();
74
       } catch (Exception e) {
75
           e.printStackTrace();
76
       }finally{
77
           //关闭资源???
78
       }
79
       return rs;
80
   }
81
 
82
   //把对数据库的增、删、改合在一起
83
   public boolean updExecute(String sql,String []paras){
84
       boolean b=true;
85
       try {
86
           //3、创建ps
87
           ps=ct.prepareStatement(sql);
88
           //给ps的问号赋值
89
           for(int i=0;i
90
               ps.setString(i+1, paras[i]);
91
           }
92
         
93
           //4、执行操作
94
           if(ps.executeUpdate()!=1){
95
               b=false;
96
           }
97
       } catch (Exception e) {
98
           b=false;
99
           JOptionPane.showMessageDialog(null, "数据源错误或数据库用户名、密码错误", "数据库连接错误提示", JOptionPane.ERROR_MESSAGE);
100
           e.printStackTrace();
101
       }finally{
102
           this.close();
103
       }
104
       return b;
105
   }
106
}

 

*******************************************************************************

[StuAddDialog.java]源码

package com.student3; import java.awt.BorderLayout; import java.awt.Frame; import java.awt.GridLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import javax.swing.JButton; import javax.swing.JDialog; import javax.swing.JLabel; import javax.swing.JOptionPane; import javax.swing.JPanel; import javax.swing.JTextField; public class StuAddDialog extends JDialog implements ActionListener{ //定义我需要的swing组件 JLabel jl1,jl2,jl3,jl4,jl5,jl6; JButton jb1,jb2; JTextField jtf1,jtf2,jtf3,jtf4,jtf5,jtf6; JPanel jp1,jp2,jp3; //owner它的父窗口;title窗口名;model指定是模态窗口,还是非模态 public StuAddDialog(Frame owner,String title,boolean modal){ super(owner,title,modal);//调用父类构造方法,达到模式对话框效果 jl1=new JLabel("学号"); jl2=new JLabel("名字"); jl3=new JLabel("性别"); jl4=new JLabel("年龄"); jl5=new JLabel("籍贯"); jl6=new JLabel("系别"); jtf1=new JTextField(); jtf2=new JTextField(); jtf3=new JTextField(); jtf4=new JTextField(); jtf5=new JTextField(); jtf6=new JTextField(); jb1=new JButton("添加"); jb2=new JButton("取消"); jp1=new JPanel(); jp2=new JPanel(); jp3=new JPanel(); //设置布局 jp1.setLayout(new GridLayout(6,1)); jp2.setLayout(new GridLayout(6,1)); //添加组件 jp1.add(jl1); jp1.add(jl2); jp1.add(jl3); jp1.add(jl4); jp1.add(jl5); jp1.add(jl6); jp2.add(jtf1); jp2.add(jtf2); jp2.add(jtf3); jp2.add(jtf4); jp2.add(jtf5); jp2.add(jtf6); jp3.add(jb1); jp3.add(jb2); this.add(jp1,BorderLayout.WEST); this.add(jp2,BorderLayout.CENTER); this.add(jp3,BorderLayout.SOUTH); jb1.addActionListener(this); jb2.addActionListener(this); //展现 this.setSize(300, 250); this.setVisible(true); } @Override public void actionPerformed(ActionEvent e) { //用户点击添加按钮后的响应动作 if(e.getSource()==jb1){ StuModel temp=new StuModel(); String sql="insert into stu values(?,?,?,?,?,?)"; String []paras={jtf1.getText(),jtf2.getText(),jtf3.getText(),jtf4.getText(),jtf5.getText(),jtf6.getText()}; if(!temp.updStu(sql, paras)){ JOptionPane.showMessageDialog(this, "添加数据失败", "添加数据提示", JOptionPane.ERROR_MESSAGE); }else{ JOptionPane.showMessageDialog(this,"添加数据成功","添加数据提示",JOptionPane.INFORMATION_MESSAGE); } //关闭对话框 this.dispose(); } else if(e.getSource()==jb2){ this.dispose(); } } }
104
 
1
package com.student3;
2
 
3
import java.awt.BorderLayout;
4
import java.awt.Frame;
5
import java.awt.GridLayout;
6
import java.awt.event.ActionEvent;
7
import java.awt.event.ActionListener;
8
import java.sql.Connection;
9
import java.sql.DriverManager;
10
import java.sql.PreparedStatement;
11
import java.sql.ResultSet;
12
import java.sql.SQLException;
13
import java.sql.Statement;
14
import javax.swing.JButton;
15
import javax.swing.JDialog;
16
import javax.swing.JLabel;
17
import javax.swing.JOptionPane;
18
import javax.swing.JPanel;
19
import javax.swing.JTextField;
20
 
21
public class StuAddDialog extends JDialog implements ActionListener{
22
   //定义我需要的swing组件
23
   JLabel jl1,jl2,jl3,jl4,jl5,jl6;
24
   JButton jb1,jb2;
25
   JTextField jtf1,jtf2,jtf3,jtf4,jtf5,jtf6;
26
   JPanel jp1,jp2,jp3;
27
 
28
   //owner它的父窗口;title窗口名;model指定是模态窗口,还是非模态
29
   public StuAddDialog(Frame owner,String title,boolean modal){
30
       super(owner,title,modal);//调用父类构造方法,达到模式对话框效果
31
       jl1=new JLabel("学号");
32
       jl2=new JLabel("名字");
33
       jl3=new JLabel("性别");
34
       jl4=new JLabel("年龄");
35
       jl5=new JLabel("籍贯");
36
       jl6=new JLabel("系别");
37
     
38
       jtf1=new JTextField();
39
       jtf2=new JTextField();
40
       jtf3=new JTextField();
41
       jtf4=new JTextField();
42
       jtf5=new JTextField();
43
       jtf6=new JTextField();
44
     
45
       jb1=new JButton("添加");
46
       jb2=new JButton("取消");
47
     
48
       jp1=new JPanel();
49
       jp2=new JPanel();
50
       jp3=new JPanel();
51
     
52
       //设置布局
53
       jp1.setLayout(new GridLayout(6,1));
54
       jp2.setLayout(new GridLayout(6,1));
55
     
56
       //添加组件
57
       jp1.add(jl1);
58
       jp1.add(jl2);
59
       jp1.add(jl3);
60
       jp1.add(jl4);
61
       jp1.add(jl5);
62
       jp1.add(jl6);
63
     
64
       jp2.add(jtf1);
65
       jp2.add(jtf2);
66
       jp2.add(jtf3);
67
       jp2.add(jtf4);
68
       jp2.add(jtf5);
69
       jp2.add(jtf6);
70
     
71
       jp3.add(jb1);
72
       jp3.add(jb2);
73
     
74
       this.add(jp1,BorderLayout.WEST);
75
       this.add(jp2,BorderLayout.CENTER);
76
       this.add(jp3,BorderLayout.SOUTH);
77
       jb1.addActionListener(this);
78
       jb2.addActionListener(this);
79
     
80
       //展现
81
       this.setSize(300, 250);
82
       this.setVisible(true);
83
   }
84
 
85
   @Override
86
   public void actionPerformed(ActionEvent e) {
87
       //用户点击添加按钮后的响应动作
88
       if(e.getSource()==jb1){
89
           StuModel temp=new StuModel();
90
           String sql="insert into stu values(?,?,?,?,?,?)";
91
           String []paras={
jtf1.getText(),jtf2.getText(),jtf3.getText(),jtf4.getText(),jtf5.getText(),jtf6.getText()};
92
           if(!temp.updStu(sql, paras)){
93
               JOptionPane.showMessageDialog(this, "添加数据失败", "添加数据提示", JOptionPane.ERROR_MESSAGE);
94
           }else{
95
               JOptionPane.showMessageDialog(this,"添加数据成功","添加数据提示",JOptionPane.INFORMATION_MESSAGE);
96
           }
97
           //关闭对话框
98
           this.dispose();
99
       }
100
       else if(e.getSource()==jb2){
101
           this.dispose();
102
       }
103
   }
104
}

 

*******************************************************************************

[StuUpdDialog.java]源码

/** * 修改学生信息 */ package com.student3; import java.awt.BorderLayout; import java.awt.Frame; import java.awt.GridLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import javax.swing.JButton; import javax.swing.JDialog; import javax.swing.JLabel; import javax.swing.JOptionPane; import javax.swing.JPanel; import javax.swing.JTextField; public class StuUpdDialog extends JDialog implements ActionListener{ //定义我需要的swing组件 JLabel jl1,jl2,jl3,jl4,jl5,jl6; JButton jb1,jb2; JTextField jtf1,jtf2,jtf3,jtf4,jtf5,jtf6; JPanel jp1,jp2,jp3; //owner它的父窗口;title窗口名;model指定是模态窗口,还是非模态 public StuUpdDialog(Frame owner,String title,boolean modal,StuModel sm,int rowNum){ super(owner,title,modal);//调用父类构造方法,达到模式对话框效果 jl1=new JLabel("学号"); jl2=new JLabel("名字"); jl3=new JLabel("性别"); jl4=new JLabel("年龄"); jl5=new JLabel("籍贯"); jl6=new JLabel("系别"); jtf1=new JTextField(); //初始化数据 jtf1.setText((String)sm.getValueAt(rowNum, 0)); //让jtf1不能修改 jtf1.setEditable(false); jtf2=new JTextField(); jtf2.setText((String)sm.getValueAt(rowNum, 1)); jtf3=new JTextField(); jtf3.setText((String)sm.getValueAt(rowNum, 2)); jtf4=new JTextField(); jtf4.setText(sm.getValueAt(rowNum, 3).toString()); jtf5=new JTextField(); jtf5.setText((String)sm.getValueAt(rowNum, 4)); jtf6=new JTextField(); jtf6.setText((String)sm.getValueAt(rowNum, 5)); jb1=new JButton("修改"); jb2=new JButton("取消"); jp1=new JPanel(); jp2=new JPanel(); jp3=new JPanel(); //设置布局 jp1.setLayout(new GridLayout(6,1)); jp2.setLayout(new GridLayout(6,1)); //添加组件 jp1.add(jl1); jp1.add(jl2); jp1.add(jl3); jp1.add(jl4); jp1.add(jl5); jp1.add(jl6); jp2.add(jtf1); jp2.add(jtf2); jp2.add(jtf3); jp2.add(jtf4); jp2.add(jtf5); jp2.add(jtf6); jp3.add(jb1); jp3.add(jb2); this.add(jp1,BorderLayout.WEST); this.add(jp2,BorderLayout.CENTER); this.add(jp3,BorderLayout.SOUTH); jb1.addActionListener(this); jb2.addActionListener(this); //展现 this.setSize(300, 250); this.setVisible(true); } @Override public void actionPerformed(ActionEvent e) { //用户点击添加按钮后的响应动作 if(e.getSource()==jb1){ //做一个sql语句 String sql="update stu set stuName=?,stuSex=?,stuAge=?,stuJg=?,stuDept=? where stuId=?"; String []paras={jtf2.getText(),jtf3.getText(),jtf4.getText(),jtf5.getText(),jtf6.getText(),jtf1.getText()}; StuModel temp=new StuModel(); if(temp.updStu(sql, paras)){ JOptionPane.showMessageDialog(this,"修改数据成功","修改数据提示",JOptionPane.INFORMATION_MESSAGE); }else{ JOptionPane.showMessageDialog(this,"修改数据失败","修改数据提示",JOptionPane.ERROR_MESSAGE); } this.dispose(); } else if(e.getSource()==jb2){ this.dispose(); } } }
125
 
1
/**
2
* 修改学生信息
3
*/
4
package com.student3;
5
 
6
import java.awt.BorderLayout;
7
import java.awt.Frame;
8
import java.awt.GridLayout;
9
import java.awt.event.ActionEvent;
10
import java.awt.event.ActionListener;
11
import java.sql.Connection;
12
import java.sql.DriverManager;
13
import java.sql.PreparedStatement;
14
import java.sql.ResultSet;
15
import java.sql.SQLException;
16
import java.sql.Statement;
17
import javax.swing.JButton;
18
import javax.swing.JDialog;
19
import javax.swing.JLabel;
20
import javax.swing.JOptionPane;
21
import javax.swing.JPanel;
22
import javax.swing.JTextField;
23
 
24
public class StuUpdDialog extends JDialog implements ActionListener{
25
   //定义我需要的swing组件
26
   JLabel jl1,jl2,jl3,jl4,jl5,jl6;
27
   JButton jb1,jb2;
28
   JTextField jtf1,jtf2,jtf3,jtf4,jtf5,jtf6;
29
   JPanel jp1,jp2,jp3;
30
 
31
   //owner它的父窗口;title窗口名;model指定是模态窗口,还是非模态
32
   public StuUpdDialog(Frame owner,String title,boolean modal,StuModel sm,int rowNum){
33
       super(owner,title,modal);//调用父类构造方法,达到模式对话框效果
34
       jl1=new JLabel("学号");
35
       jl2=new JLabel("名字");
36
       jl3=new JLabel("性别");
37
       jl4=new JLabel("年龄");
38
       jl5=new JLabel("籍贯");
39
       jl6=new JLabel("系别");
40
     
41
       jtf1=new JTextField();
42
       //初始化数据
43
       jtf1.setText((String)sm.getValueAt(rowNum, 0));
44
       //让jtf1不能修改
45
       jtf1.setEditable(false);
46
       jtf2=new JTextField();
47
       jtf2.setText((String)sm.getValueAt(rowNum, 1));
48
       jtf3=new JTextField();
49
       jtf3.setText((String)sm.getValueAt(rowNum, 2));
50
       jtf4=new JTextField();
51
       jtf4.setText(sm.getValueAt(rowNum, 3).toString());
52
       jtf5=new JTextField();
53
       jtf5.setText((String)sm.getValueAt(rowNum, 4));
54
       jtf6=new JTextField();
55
       jtf6.setText((String)sm.getValueAt(rowNum, 5));
56
     
57
       jb1=new JButton("修改");
58
       jb2=new JButton("取消");
59
     
60
       jp1=new JPanel();
61
       jp2=new JPanel();
62
       jp3=new JPanel();
63
     
64
       //设置布局
65
       jp1.setLayout(new GridLayout(6,1));
66
       jp2.setLayout(new GridLayout(6,1));
67
     
68
       //添加组件
69
       jp1.add(jl1);
70
       jp1.add(jl2);
71
       jp1.add(jl3);
72
       jp1.add(jl4);
73
       jp1.add(jl5);
74
       jp1.add(jl6);
75
     
76
       jp2.add(jtf1);
77
       jp2.add(jtf2);
78
       jp2.add(jtf3);
79
       jp2.add(jtf4);
80
       jp2.add(jtf5);
81
       jp2.add(jtf6);
82
     
83
       jp3.add(jb1);
84
       jp3.add(jb2);
85
     
86
       this.add(jp1,BorderLayout.WEST);
87
       this.add(jp2,BorderLayout.CENTER);
88
       this.add(jp3,BorderLayout.SOUTH);
89
     
90
       jb1.addActionListener(this);
91
       jb2.addActionListener(this);
92
     
93
       //展现
94
       this.setSize(300, 250);
95
       this.setVisible(true);
96
   }
97
 
98
   @Override
99
   public void actionPerformed(ActionEvent e) {
100
       //用户点击添加按钮后的响应动作
101
       if(e.getSource()==jb1){
102
           //做一个sql语句
103
           String sql="update stu set stuName=?,stuSex=?,stuAge=?,stuJg=?,stuDept=? where stuId=?";
104
           String []paras={
jtf2.getText(),jtf3.getText(),jtf4.getText(),jtf5.getText(),jtf6.getText(),jtf1.getText()};
105
           StuModel temp=new StuModel();
106
           if(temp.updStu(sql, paras)){
107
               JOptionPane.showMessageDialog(this,"修改数据成功","修改数据提示",JOptionPane.INFORMATION_MESSAGE);
108
           }else{
109
               JOptionPane.showMessageDialog(this,"修改数据失败","修改数据提示",JOptionPane.ERROR_MESSAGE);
110
           }
111
           this.dispose();
112
       }
113
       else if(e.getSource()==jb2){
114
           this.dispose();
115
       }
116
   }
117
}
118
 

转载于:https://www.cnblogs.com/xuxaut-558/p/10045826.html

你可能感兴趣的文章
Python之第一个程序
查看>>
习题总结(二)——禁ctrl+alt+delete,禁普通用户登录,禁ping
查看>>
localStorage只能存储字符串
查看>>
【Spring Boot】11.使用docker安装常见服务
查看>>
原子操作的实现
查看>>
HashMap实现原理及源码分析
查看>>
OpenSSL命令之算法类大全
查看>>
MailBee.NET Objects发送电子邮件(SMTP)教程八:使用多个SMTP服务器发送邮件
查看>>
如何在VS CODE调试Angular
查看>>
学习Linux系统的方法有很多,适合自己的才是最好。
查看>>
DRAM和NAND Flash合约价持续走下坡路
查看>>
KVM网桥
查看>>
初尝- 搭建数据库MySql环境
查看>>
Yii2页面缓存详解
查看>>
ECMAScript正则表达式6个最新特性
查看>>
android Studio 快捷键
查看>>
MySQL Explain
查看>>
Java NIO
查看>>
1、图片水印 之 一
查看>>
分布式锁
查看>>