1、修改窗体

2、在StudentDao中增加修改学生信息的方法

	/**
* 修改的方法
*
* @param student
* @return
* @throws SQLException
*/
public boolean update(Student student) throws SQLException {
DbUtil dbUtil = new DbUtil();
String sql = "update tb_student set name='" + student.getName() + "',sno='"
+ student.getSno() + "',sex='" + student.getSex()
+ "',classname='" + student.getClassName() + "' where id ='"
+ student.getId() + "'";
// 在控制台打印sql语句用于检查
System.out.println(sql);
// 处理并返回
return dbUtil.execute(sql);
}

  

3、在StudentService中增加修改服务

	/**
* 修改学生信息服务
*
* @param student
* @return
* @throws SQLException
*/
public boolean editStudent(Student student) throws SQLException {
StudentDao studentDao = new StudentDao();
return studentDao.update(student);
}

4、给窗体中的表格添加点击事件

表格单击完整代码

		table.addMouseListener(new MouseAdapter() {
@Override
public void mousePressed(MouseEvent e) {
int row = table.getSelectedRow();
textField_1.setText(table.getValueAt(row, 1) + "");
textField_2.setText(table.getValueAt(row, 2) + "");
String sex = table.getValueAt(row, 3) + "";
if ("男".equals(sex)) {
boy.setSelected(true);
} else if ("女".equals(sex)) {
girl.setSelected(true);
}
}
});

  

5、提交并处理修改过的内容

			btnNewButton.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
//获取学号
String sno = textField_1.getText().trim();
//获取姓名
String name = textField_2.getText().trim();
//获取性别
String sex = "";
if (boy.isSelected()) {
sex = "男";
} else if (girl.isSelected()) {
sex = "女";
}
//获取班级
String className = comboBox.getSelectedItem().toString();
//说明id已经在前面保存了;
//构建窗体
Student student = new Student(id, sno, name, sex, className);
try {
if (service.editStudent(student)) {
JOptionPane.showMessageDialog(null, "修改成功");
} else {
JOptionPane.showMessageDialog(null, "修改失败");
}
} catch (SQLException e1) {
e1.printStackTrace();
}
}
});

6、截图

7、完整代码

package com.student.view;

import java.awt.EventQueue;
import java.sql.SQLException;
import java.util.List; import javax.swing.ButtonGroup;
import javax.swing.JFrame;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.border.EmptyBorder;
import javax.swing.table.DefaultTableModel; import com.student.model.Student;
import com.student.service.StudentService; import javax.swing.JLabel;
import javax.swing.JTextField;
import javax.swing.JButton; import java.awt.event.ActionListener;
import java.awt.event.ActionEvent; import javax.swing.JRadioButton;
import javax.swing.JComboBox;
import javax.swing.DefaultComboBoxModel; import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent; /*
* 项目名称:
*
* 文件名称为:ShowStudent.java
* 文件创建人:daxiang
*
* @author daxiang
* @version
* @time 2018年6月22日 上午8:03:24
* @copyright daxiang
*/
public class ShowStudent extends JFrame { private static final long serialVersionUID = 1L;
private JPanel contentPane;
private JTable table;
private JTextField textField;
private JLabel lblNewLabel;
private JLabel lblNewLabel_1;
private JLabel lblNewLabel_2;
private JLabel lblNewLabel_3;
private JTextField textField_1;
private JTextField textField_2;
private JRadioButton boy;
private JRadioButton girl;
private int id;// 保存修改时的ID /**
* Launch the application.
*/
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
public void run() {
try {
ShowTable frame = new ShowTable();
frame.setVisible(true);
} catch (Exception e) {
e.printStackTrace();
}
}
});
} /**
* Create the frame.
*/
public ShowStudent() {
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
setBounds(100, 100, 860, 618);
contentPane = new JPanel();
contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
setContentPane(contentPane);
// 设置无布局
contentPane.setLayout(null);
// 创建滚动面板
JScrollPane scrollPane = new JScrollPane();
scrollPane.setBounds(37, 89, 739, 263);
contentPane.add(scrollPane);
// 创建表格
table = new JTable();
table.addMouseListener(new MouseAdapter() {
@Override
public void mousePressed(MouseEvent e) {
int row = table.getSelectedRow();
id = (int) table.getValueAt(row, 0);
textField_1.setText(table.getValueAt(row, 1) + "");
textField_2.setText(table.getValueAt(row, 2) + "");
String sex = table.getValueAt(row, 3) + "";
if ("男".equals(sex)) {
boy.setSelected(true);
} else if ("女".equals(sex)) {
girl.setSelected(true);
}
}
}); // 将表格加载到滚动面板
scrollPane.setViewportView(table);
try {
// 创建服务
StudentService service = new StudentService();
// 查询出所有学生
List<Student> list = service.getStudent();
// 装载数据
fillTable(list); JLabel label = new JLabel("请输入学生姓名:");
label.setBounds(93, 43, 123, 18);
contentPane.add(label); textField = new JTextField();
textField.setBounds(242, 40, 169, 24);
contentPane.add(textField);
textField.setColumns(10); JButton button = new JButton("查 找");
button.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
try {
// 获取查询数据
// textField.getText().trim()获取文本框数据并且去掉空格
List<Student> list1 = service.getStudent(textField
.getText().trim());
// 装载到表格
fillTable(list1);
} catch (SQLException e1) {
e1.printStackTrace();
}
}
});
button.setBounds(477, 39, 113, 27);
contentPane.add(button); lblNewLabel = new JLabel("学 号");
lblNewLabel.setBounds(86, 383, 52, 18);
contentPane.add(lblNewLabel); lblNewLabel_1 = new JLabel("姓名");
lblNewLabel_1.setBounds(306, 383, 43, 18);
contentPane.add(lblNewLabel_1); lblNewLabel_2 = new JLabel("班 级");
lblNewLabel_2.setBounds(86, 438, 52, 18);
contentPane.add(lblNewLabel_2); lblNewLabel_3 = new JLabel("性别");
lblNewLabel_3.setBounds(516, 383, 43, 18);
contentPane.add(lblNewLabel_3); textField_1 = new JTextField();
textField_1.setBounds(152, 380, 140, 24);
contentPane.add(textField_1);
textField_1.setColumns(10); textField_2 = new JTextField();
textField_2.setBounds(363, 380, 123, 24);
contentPane.add(textField_2);
textField_2.setColumns(10); ButtonGroup buttonGroup = new ButtonGroup(); boy = new JRadioButton("男");
boy.setBounds(571, 379, 52, 27);
contentPane.add(boy); girl = new JRadioButton("女");
girl.setBounds(639, 379, 52, 27);
contentPane.add(girl); buttonGroup.add(girl);
buttonGroup.add(boy); JComboBox<String> comboBox = new JComboBox<String>();
comboBox.setModel(new DefaultComboBoxModel<String>(new String[] {
"计科1班", "计科2班", "计科3班", "计科4班" }));
comboBox.setBounds(152, 435, 140, 24);
contentPane.add(comboBox); JButton btnNewButton = new JButton("修 改");
// 处理修改
btnNewButton.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
// 获取学号
String sno = textField_1.getText().trim();
// 获取姓名
String name = textField_2.getText().trim();
// 获取性别
String sex = "";
if (boy.isSelected()) {
sex = "男";
} else if (girl.isSelected()) {
sex = "女";
}
// 获取班级
String className = comboBox.getSelectedItem().toString();
// 说明id已经在前面保存了;
// 构建窗体
Student student = new Student(id, sno, name, sex, className);
try {
if (service.editStudent(student)) {
JOptionPane.showMessageDialog(null, "修改成功");
} else {
JOptionPane.showMessageDialog(null, "修改失败");
}
} catch (SQLException e1) {
e1.printStackTrace();
}
}
});
btnNewButton.setBounds(346, 434, 113, 27);
contentPane.add(btnNewButton); JButton btnNewButton_1 = new JButton("删除");
btnNewButton_1.setBounds(516, 434, 113, 27);
contentPane.add(btnNewButton_1);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
          setVisible(true);
} /**
* 表格装载数据
*
* @param list
*/
public void fillTable(List<Student> list) {
// 将默认的加载数据去掉,重新定义个表头
String[] head = new String[] { "序号", "学号", "姓名", "性别", "班级" };
// 创建一个二维数组,5表示列数
Object[][] data = new Object[list.size()][5];
// 遍历
for (int i = 0; i < list.size(); i++) {
data[i][0] = list.get(i).getId();
data[i][1] = list.get(i).getSno();
data[i][2] = list.get(i).getName();
data[i][3] = list.get(i).getSex();
data[i][4] = list.get(i).getClassName();
}
// 将数据和表头封装
DefaultTableModel datamoModel = new DefaultTableModel(data, head);
// 将封装好的数据加载
table.setModel(datamoModel);
}
}

  

Java课程设计---修改学生基本信息的更多相关文章

  1. Java课程设计---删除学生

    1.界面已经在上次修改操作的过程添加完成 2.在StudentDao中添加删除方法 public boolean delete(int id) throws SQLException { DbUtil ...

  2. Java课程设计---浏览学生(实现根据姓名查询)

    1.修改窗口 2.在StudentDao中增加根据姓名查找的方法 public List<Student> getStudent(String name)throws SQLExcepti ...

  3. Java课程设计报告——学生成绩管理系统

    一.需求分析 1.数据存储在数据库和文件中 2.分为"教师"模块和"学生"模块. 3.学生模块提供登陆功能,登陆成功后可查询数学.Java.体育成绩 (学生学号 ...

  4. Java课程设计---添加学生

    1.创建添加窗体 package com.student.view; import java.awt.EventQueue; import javax.swing.ButtonGroup; impor ...

  5. Java课程设计---浏览学生(表格的使用)

    1.创建显示表格的窗体 package com.student.view; import java.awt.EventQueue; import javax.swing.JFrame; import ...

  6. Java课程设计---索引

    一.基础配置 ============================================================== 1.Java课程设计---Eclipse基本环境配置 2.J ...

  7. Java课程设计—学生成绩管理系统(201521123004-林艺如)

    1.团队课程设计博客 团队课程设计博客链接 2.个人负责模块或任务说明 ①.Menu Menu.jsp 在页面中给出提示,用HTML的 MenuTeacher.jsp 利用Menu.jsp进行具体化完 ...

  8. Java课程设计——学生成绩管理系统(201521123003 董美凤)

    Java课程设计--学生成绩管理系统(201521123003 董美凤) 1.团队课程设计博客链接 学生成绩管理系统博客链接 2.个人负责模块或任务说明 信息修改 密码修改 部分界面设计 3.自己的代 ...

  9. Java课程设计——博客作业教学数据分析系统(201521123084 林正晟)

    #课程设计--博客作业教学数据分析系统(201521123084 林正晟) 1.团队课程设计博客链接 博客作业教学数据分析系统 2.个人负责模块或任务说明 学生登陆界面的前端实现和与数据库的连接 学生 ...

随机推荐

  1. 感恩陪伴 HelloGitHub 定制的红包封面

    距离放假越来越近了,我们更文的频率也越来越低了. 先别打!听我解释... 我真没偷懒,我是去研究今年的「微信红包封面」玩法了. 这不去年,我们制作的 HelloGitHub 专属红包封面,很多粉丝都说 ...

  2. 分享一个基于 ABP(.NET 5.0) + vue-element-admin 管理后台

    1.前言 分享一个基于ABP(.NET 5.0) + vue-element-admin项目.希望可以降低新手对于ABP框架的学习成本,感兴趣的同学可以下载项目启动运行一下.对于想选型采用ABP框架的 ...

  3. Windows 10 Version 21h1安装

    好久没安装过Windows 10系统了,这两天在下载电脑管家时,使用bing搜索,没注意就选择了第一个,安装后,噩梦就来了,非法广告.各种软件的推送,怎么也清不干净. 没办法,到PCBeta下载了最新 ...

  4. 安装Windows11操作系统(不需要绕过TPM检测脚本等) - 初学者系列 - 学习者系列文章

    Windows11操作系统是去年微软公司的最新力作.对于该操作系统的安装,网上有很多的教程了.这次主要写的是不需要绕过TPM检测操作安装Windows11操作系统. 1.        制作启动U盘: ...

  5. Java多线程专题5: JUC, 锁

    合集目录 Java多线程专题5: JUC, 锁 什么是可重入锁.公平锁.非公平锁.独占锁.共享锁 可重入锁 ReentrantLock A ReentrantLock is owned by the ...

  6. Luogu_P1613跑路

    跳转链接 题目大意 题目中要求的是从1号点到n号点所需要的最短时间, 一秒可以走 \(2^k\) 个距离 给定的有向图的边边权都是1. 问题分析 由于一秒可以走 \(2^k\) 个距离,因此题目转化为 ...

  7. 看一遍就懂:MVCC原理详解

    MVCC实现原理也是一道非常高频的面试题,自己在整理这篇文章的时候,感觉到网上的资料在讲这块知识点上写的五花八门,好像大家的理解并没有一致. 这里将自己所理解的做一个总结,个人会觉得这是一篇含金量挺高 ...

  8. java实现HTTPS单向认证&TLS指定加密套件

    1.HTTPS介绍 由于HTTP是明文传输,会造成安全隐患,所以在一些特定场景中,必须使用HTTPS协议,简单来说HTTPS=HTTP+SSL/TLS.服务端和客户端的信息传输都是通过TLS进行加密. ...

  9. 实现Nginx代理WSS协议

    因为线上H5游戏需要加上SSL,不想在原来的Web 服务器和游戏服务器支持SSL,只希望 在Nginx代理集群支持SSL.整体架构如下: 从上图可以看出需要总共涉及到https/http 和wss/w ...

  10. CSS 3D的魅力

    用户1093975发表于Web项目聚集地订阅 151 在这篇文章中: 前言: demo1 demo2 结语: 本文介绍了CSS来实现3D效果,并且有详细代码和解释.建议大家只字不差的阅读.本文的作者是 ...