JAVA入门到精通-第72讲-学生管理系统4-model 2模式(1)

1167156-20181130181908094-540770480.png
删除、查询、添加、修改:
-修改:
1167156-20181130181908505-1565833885.png
每个字段都可能修改:

1167156-20181130181908901-1636185517.png

1167156-20181130181909213-516664444.png
//给?赋值
1167156-20181130181909398-960689538.png
//在prepareStatement语句后面赋值才好用

1167156-20181130181909632-1249889416.png

//修改完了,更新数据
1167156-20181130181910156-1112860409.png
1167156-20181130181910630-554766364.png

1167156-20181130181910990-349156288.png
1167156-20181130181911323-802054870.png
1167156-20181130181911592-1326516453.png

目前为止,已经完成了增删改查-Model1模式
最大特点:
界面和业务逻辑操作是放在一起的;
优点:简单,开发方便;

缺点:代码复用性不高;
中大型项目可读性差, 可维护性不高;
前台后端混杂在一起的;
比如:“数据库密码换了,
所有涉及到数据库的地方都需要发生变化”
=================================
=================================
Model2模式:界面和操作分离
思想是最重要的;
1167156-20181130181911893-1982718474.png
数据库的操作全部交给StuModel处理;
对数据库的维护比较方便,比如数据库的密码,地址变化了,
就改动数据模型StuModel就可以了;

-简单的model2模式
界面(view)和模型(model/后台/业务逻辑层)
最大特点:界面和后台操作是分离的;
优点:代码复用性好、可读性高、可维护性好;
缺点:相对来说比较复杂;

//添加学生
默认是添加成功的
1167156-20181130181912225-1793473537.png

可以把数据库的地址、用户名、密码作为成员变量,
传参数进去,这样 方便日后的修改;
以后更换数据库比较方便;
1167156-20181130181912496-1237755912.png
1167156-20181130181912778-1589856740.png

可以通过字符串数组String []paras 方式把参数传进来
1167156-20181130181913047-89795719.png
1167156-20181130181913266-1733799979.png
i+1,传进来的参数是从0开始编号的;

1167156-20181130181913584-834123369.png

1167156-20181130181913853-123615140.png

1167156-20181130181914072-556666743.png
//弹出消息框JOptionPane.showMessageDialog(this,"添加失败");
//关闭对话框
this.dispose();
1167156-20181130181914316-1122516529.png

---------------------
-删除,把增删改全部写在“添加学生”模块
-public boolean updStu
1167156-20181130181914696-454848454.png
-修改
1167156-20181130181914981-1696281975.png
1167156-20181130181915267-685680217.png
1167156-20181130181915574-1190752557.png

==============
-专门做一个函数,得到数据:
不要让构造函数和得到数据混在一起;

1167156-20181130181915865-782625811.png


1167156-20181130181916139-1352740886.png
在不知道的情况下,对数据库进行了一次查询

[JTable_Test3.java]源码

/** * 完成一个mini版本的学生管理系统(MODEL2模式) * 1、查询任务 * 2、添加功能 */ package com.student2; 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(); //初始化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); } public void actionPerformed(ActionEvent e) { if(e.getSource()==jb1){ //因为把对表的数据封装到StuModel中,我们就可以比较简单的完成查询 String name=this.jtf.getText(); //写一个SQL语句 String sql="select * from stu where stuName='"+name+"'"; //构建新的数据模型类,并更新 sm=new StuModel(sql); //更新JTable jt.setModel(sm); } //用户点击添加时 else if(e.getSource()==jb2){ StuAddDialog sa=new StuAddDialog(this, "添加学生", true); //重新再获得新的数据模型 //构建新的数据模型类,并更新 sm=new StuModel(); //更新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(); //更新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(); //更新JTable jt.setModel(sm); } } }
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]源码

/** * 这是一个stu表的模型 * 可以把对student表的各种操作封装到该模型中 */ package com.student2; 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; //定义操作数据库需要的组件 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 boolean updStu(String sql,String []paras){ boolean b=true; try { //1、加载驱动 Class.forName(sqlDriver); //2、得到连接 ct=DriverManager.getConnection(url); //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{ try { if(rs!=null){ rs.close(); } if(ps!=null){ ps.close(); } if(ct!=null){ ct.close(); } } catch (SQLException e1) { e1.printStackTrace(); } } return b; } public void init(String sql){ if(sql==""||sql.equals(null)){ sql="select * from stu"; } //中间 columnNames=new Vector<>(); //设置列名 columnNames.add("学号"); columnNames.add("名字"); columnNames.add("性别"); columnNames.add("年龄"); columnNames.add("籍贯"); columnNames.add("系别"); rowData=new Vector<>(); //rowData可以存放多行 try { //1、加载驱动 Class.forName(sqlDriver); //2、得到连接 ct=DriverManager.getConnection(url); ps=ct.prepareStatement(sql); rs=ps.executeQuery(); 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{ try { if(rs!=null){ rs.close(); } if(ps!=null){ ps.close(); } if(ct!=null){ ct.close(); } } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } //构造函数,用于初始我们的数据模型 public StuModel(String sql){ this.init(sql); } //构造函数 public StuModel(){ this.init(""); } //得到共有多少列 public int getColumnCount() { return this.columnNames.size(); } 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); } }
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]源码

/** * 添加数据 */ package com.student2; 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); } 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(); } } }
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]源码

/** * 修改学生信息 */ package com.student2; 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(); } } }
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
 
          





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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值