刪除、查詢、添加、修改:
-修改:
每個字段都可能修改:
//給?賦值
//在prepareStatement語句后面賦值才好用
//修改完了,更新數據
目前為止,已經完成了增刪改查-Model1模式
最大特點:
界面和業務邏輯操作是放在一起的;
優點:簡單,開發方便;
缺點:代碼復用性不高;
中大型項目可讀性差,
可維護性不高;
前台后端混雜在一起的;
比如:“數據庫密碼換了,
所有涉及到數據庫的地方都需要發生變化”
=================================
=================================
Model2模式:界面和操作分離
思想是最重要的;
數據庫的操作全部交給StuModel處理;
對數據庫的維護比較方便,比如數據庫的密碼,地址變化了,
就改動數據模型StuModel就可以了;
-簡單的model2模式
界面(view)和模型(model/后台/業務邏輯層)
最大特點:界面和后台操作是分離的;
優點:代碼復用性好、可讀性高、可維護性好;
缺點:相對來說比較復雜;
默認是添加成功的
可以把數據庫的地址、用戶名、密碼作為成員變量,
傳參數進去,這樣
方便日后的修改;
以后更換數據庫比較方便;
可以通過字符串數組String []paras 方式把參數傳進來
i+1,傳進來的參數是從0開始編號的;
//彈出消息框JOptionPane.showMessageDialog(this,"添加失敗");
//關閉對話框
this.dispose();
---------------------
-刪除,把增刪改全部寫在“添加學生”模塊
-public boolean updStu
156
156
1
/**
2
* 完成一個mini版本的學生管理系統(MODEL2模式)
3
* 1、查詢任務
4
* 2、添加功能
5
*/
6
package com.student2;
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
jp2=new JPanel();
58
jb2=new JButton("添加");
59
jb2.addActionListener(this);
60
jb3=new JButton("修改");
61
jb3.addActionListener(this);
62
jb4=new JButton("刪除");
63
jb4.addActionListener(this);
64
65
//把各個按鈕加入到jp2中
66
jp2.add(jb2);
67
jp2.add(jb3);
68
jp2.add(jb4);
69
70
//創建一個數據模型對象
71
sm=new StuModel();
72
73
//初始化JTable
74
jt=new JTable(sm);
75
76
//初始化jsp JScrollPane
77
jsp=new JScrollPane(jt);
78
79
//把jsp放入到jframe
80
this.add(jsp);
81
this.add(jp1,"North");
82
this.add(jp2,"South");
83
84
this.setSize(400, 300);
85
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
86
this.setVisible(true);
87
}
88
89
public void actionPerformed(ActionEvent e) {
90
if(e.getSource()==jb1){
91
//因為把對表的數據封裝到StuModel中,我們就可以比較簡單的完成查詢
92
String name=this.jtf.getText();
93
//寫一個SQL語句
94
String sql="select * from stu where stuName='"+name+"'";
95
//構建新的數據模型類,並更新
96
sm=new StuModel(sql);
97
//更新JTable
98
jt.setModel(sm);
99
}
100
//用戶點擊添加時
101
else if(e.getSource()==jb2){
102
StuAddDialog sa=new StuAddDialog(this, "添加學生", true);
103
//重新再獲得新的數據模型
104
//構建新的數據模型類,並更新
105
sm=new StuModel();
106
//更新JTable
107
jt.setModel(sm);
108
}
109
//用戶修改數據
110
else if(e.getSource()==jb3){
111
int rowNum=this.jt.getSelectedRow();
112
if(rowNum==-1){
113
//提示
114
JOptionPane.showMessageDialog(this, "請選擇一行", "提示", JOptionPane.INFORMATION_MESSAGE);
115
return;
116
}
117
118
//顯示修改對話框
119
new StuUpdDialog(this,"修改學生信息",true,sm,rowNum);
120
121
//更新數據模型
122
sm=new StuModel();
123
//更新JTable
124
jt.setModel(sm);
125
}
126
127
//用戶點擊刪除時,刪除一條選中的數據
128
else if(e.getSource()==jb4){
129
//1、得到學生的ID號
130
//getSelectedRow會返回用戶點中的行
131
//如果該用戶一行都沒有選擇,就會返回-1
132
int rowNum=this.jt.getSelectedRow();
133
if(rowNum==-1){
134
//提示
135
JOptionPane.showMessageDialog(this, "請選擇一行", "提示", JOptionPane.INFORMATION_MESSAGE);
136
return;
137
}
138
//得到學生編號
139
String stuId=(String)sm.getValueAt(rowNum, 0);
140
//創建一個sql語句
141
String sql="delete from stu where stuid=?";
142
String []paras={stuId};
143
StuModel temp=new StuModel();
144
if(temp.updStu(sql, paras)){
145
JOptionPane.showMessageDialog(this,"刪除數據成功","刪除數據提示",JOptionPane.INFORMATION_MESSAGE);
146
}else{
147
JOptionPane.showMessageDialog(this,"刪除數據失敗","刪除數據提示",JOptionPane.ERROR_MESSAGE);
148
}
149
150
//更新數據模型
151
sm=new StuModel();
152
//更新JTable
153
jt.setModel(sm);
154
}
155
}
156
}
*******************************************************************[StuModel.java]源碼
152
152
1
/**
2
* 這是一個stu表的模型
3
* 可以把對student表的各種操作封裝到該模型中
4
*/
5
package com.student2;
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
PreparedStatement ps=null;
21
Connection ct=null;
22
ResultSet rs=null;
23
String sqlDriver="com.microsoft.sqlserver.jdbc.SQLServerDriver";
24
String url="jdbc:sqlserver://127.0.0.1:1433;databaseName=stussystem;user=sa;password=sa;";
25
26
//添加學生(增、刪、改)
27
public boolean updStu(String sql,String []paras){
28
boolean b=true;
29
try {
30
//1、加載驅動
31
Class.forName(sqlDriver);
32
//2、得到連接
33
ct=DriverManager.getConnection(url);
34
//3、創建ps
35
ps=ct.prepareStatement(sql);
36
//給ps的問號賦值
37
for(int i=0;i<paras.length;i++){
38
ps.setString(i+1, paras[i]);
39
}
40
41
//4、執行操作
42
if(ps.executeUpdate()!=1){
43
b=false;
44
}
45
46
} catch (Exception e) {
47
b=false;
48
JOptionPane.showMessageDialog(null, "數據源錯誤或數據庫用戶名、密碼錯誤", "數據庫連接錯誤提示", JOptionPane.ERROR_MESSAGE);
49
e.printStackTrace();
50
}finally{
51
try {
52
if(rs!=null){
53
rs.close();
54
}
55
if(ps!=null){
56
ps.close();
57
}
58
if(ct!=null){
59
ct.close();
60
}
61
} catch (SQLException e1) {
62
e1.printStackTrace();
63
}
64
}
65
return b;
66
}
67
68
public void init(String sql){
69
if(sql==""||sql.equals(null)){
70
sql="select * from stu";
71
}
72
//中間
73
columnNames=new Vector<>();
74
//設置列名
75
columnNames.add("學號");
76
columnNames.add("名字");
77
columnNames.add("性別");
78
columnNames.add("年齡");
79
columnNames.add("籍貫");
80
columnNames.add("系別");
81
82
rowData=new Vector<>();
83
//rowData可以存放多行
84
try {
85
//1、加載驅動
86
Class.forName(sqlDriver);
87
//2、得到連接
88
ct=DriverManager.getConnection(url);
89
90
ps=ct.prepareStatement(sql);
91
rs=ps.executeQuery();
92
93
while(rs.next()){
94
Vector hang=new Vector();
95
hang.add(rs.getString(1));
96
hang.add(rs.getString(2));
97
hang.add(rs.getString(3));
98
hang.add(rs.getInt(4));
99
hang.add(rs.getString(5));
100
hang.add(rs.getString(6));
101
//加入rowData
102
rowData.add(hang);
103
}
104
} catch (Exception e) {
105
e.printStackTrace();
106
}finally{
107
try {
108
if(rs!=null){
109
rs.close();
110
}
111
if(ps!=null){
112
ps.close();
113
}
114
if(ct!=null){
115
ct.close();
116
}
117
} catch (SQLException e) {
118
// TODO Auto-generated catch block
119
e.printStackTrace();
120
}
121
}
122
}
123
124
//構造函數,用於初始我們的數據模型
125
public StuModel(String sql){
126
this.init(sql);
127
}
128
129
//構造函數
130
public StuModel(){
131
this.init("");
132
}
133
134
//得到共有多少列
135
public int getColumnCount() {
136
return this.columnNames.size();
137
}
138
139
public String getColumnName(int column) {
140
return (String)this.columnNames.get(column);
141
}
142
143
//得到共有多少行
144
public int getRowCount() {
145
return this.rowData.size();
146
}
147
148
//得到某行某列的數據
149
public Object getValueAt(int rowIndex, int columnIndex) {
150
return ((Vector)this.rowData.get(rowIndex)).get(columnIndex);
151
}
152
}
*******************************************************************************
[StuAddDialog.java]源碼
106
106
1
/**
2
* 添加數據
3
*/
4
package com.student2;
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 StuAddDialog 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 StuAddDialog(Frame owner,String title,boolean modal){
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
jtf2=new JTextField();
43
jtf3=new JTextField();
44
jtf4=new JTextField();
45
jtf5=new JTextField();
46
jtf6=new JTextField();
47
48
jb1=new JButton("添加");
49
jb2=new JButton("取消");
50
51
jp1=new JPanel();
52
jp2=new JPanel();
53
jp3=new JPanel();
54
55
//設置布局
56
jp1.setLayout(new GridLayout(6,1));
57
jp2.setLayout(new GridLayout(6,1));
58
59
//添加組件
60
jp1.add(jl1);
61
jp1.add(jl2);
62
jp1.add(jl3);
63
jp1.add(jl4);
64
jp1.add(jl5);
65
jp1.add(jl6);
66
67
jp2.add(jtf1);
68
jp2.add(jtf2);
69
jp2.add(jtf3);
70
jp2.add(jtf4);
71
jp2.add(jtf5);
72
jp2.add(jtf6);
73
74
jp3.add(jb1);
75
jp3.add(jb2);
76
77
this.add(jp1,BorderLayout.WEST);
78
this.add(jp2,BorderLayout.CENTER);
79
this.add(jp3,BorderLayout.SOUTH);
80
jb1.addActionListener(this);
81
jb2.addActionListener(this);
82
83
//展現
84
this.setSize(300, 250);
85
this.setVisible(true);
86
}
87
88
public void actionPerformed(ActionEvent e) {
89
//用戶點擊添加按鈕后的響應動作
90
if(e.getSource()==jb1){
91
StuModel temp=new StuModel();
92
String sql="insert into stu values(?,?,?,?,?,?)";
93
String []paras={jtf1.getText(),jtf2.getText(),jtf3.getText(),jtf4.getText(),jtf5.getText(),jtf6.getText()};
94
if(!temp.updStu(sql, paras)){
95
JOptionPane.showMessageDialog(this, "添加數據失敗", "添加數據提示", JOptionPane.ERROR_MESSAGE);
96
}else{
97
JOptionPane.showMessageDialog(this,"添加數據成功","添加數據提示",JOptionPane.INFORMATION_MESSAGE);
98
}
99
//關閉對話框
100
this.dispose();
101
}
102
else if(e.getSource()==jb2){
103
this.dispose();
104
}
105
}
106
}
******************************************************************
[StuUpdDialog.java]源碼
x
118
1
/**
2
* 修改學生信息
3
*/
4
package com.student2;
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






