JAVA入门到精通-第72讲-学生管理系统4-model 2模式
Posted 夏至稻花如白练,大暑池畔赏红莲
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA入门到精通-第72讲-学生管理系统4-model 2模式相关的知识,希望对你有一定的参考价值。
删除、查询、添加、修改:
-修改:
每个字段都可能修改:
//给?赋值
//在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
JAVA入门到精通-第69讲-学生管理系统1.项目分析