实训第六天(学生信息管理系统)
实训第六天(学生信息管理系统)
一、创建一个类用来编辑学生信息
1、EditStudentFrame
2.先是构造方法、
3.主方法、
4.初始化界面、组件、面板、标签、按钮、当前记录行、学生列表、创建学生服务对象、再是创建组件、
5.添加组件
6、窗口的属性、窗口的大小、窗口屏幕居中、窗口可见、设置默认关闭操作、获取全部学生的列表、
7、上一条按钮单击事件、下一条按钮单击事件、
![在这里插入图片描述](https://img-blog.csdnimg.cn/20190622110556731.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80NDcwMTQ2Mg==,size_16,color_FFFFFF,t_70/8、最后一条按钮单击事件、退出按钮单击事件、编辑按钮单击事件、确定按钮单击事件、
9、
取消按钮单击事件、恢复文本框修改前的值、姓名文本框按键事件、性别文本框按键事件、将当前记录数据填充窗口各文本框、文本框按键事件。
10.代码如下:
package net.zxk.student.gui;
import net.zxk.student.bean.Student;
import net.zxk.student.service.StudentService;
import net.zxk.student.service.impl.StudentServiceImpl;
import javax.swing.;
import java.awt.;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/**
-
功能:编辑学生记录
-
作者:周许苛
-
日期:2019年6月22日
/
public class EditStudentFrame extends JFrame {
/*- 声明面板
/
private JPanel panel;
private JPanel pnlCenter;
private JPanel pnlRow1;
private JPanel pnlRow2;
private JPanel pnlRow3;
private JPanel pnlRow4;
private JPanel pnlRow5;
private JPanel pnlRow6;
private JPanel pnlRow7;
private JPanel pnlSouth;
private JPanel pnlSouth1;
private JPanel pnlSouth2;
/* - 声明标签
/
private JLabel lblId;
private JLabel lblName;
private JLabel lblSex;
private JLabel lblAge;
private JLabel lblDepartment;
private JLabel lblClass;
private JLabel lblTelephone;
/* - 声明文本框
/
private JTextField txtId;
private JTextField txtName;
private JTextField txtSex;
private JTextField txtAge;
private JTextField txtDepartment;
private JTextField txtClass;
private JTextField txtTelephone;
/* - 声明按钮
/
private JButton btnTop;
private JButton btnPrevious;
private JButton btnNext;
private JButton btnBottom;
private JButton btnExit;
private JButton btnEdit;
private JButton btnOK;
private JButton btnCancel;
/* - 当前记录行号
/
private int currentRow;
/* - 学生列表
/
private List students;
/* - 创建学生服务对象
*/
StudentService studentService;
/**
- 构造方法
- @param title
*/
public EditStudentFrame(String title) {
super(title);
initGUI();
}
/**
-
初始化用户界面
*/
private void initGUI() {
// 创建组件
panel = (JPanel) getContentPane();
pnlCenter = new JPanel();
pnlSouth = new JPanel();
pnlSouth.setLayout(new GridLayout(2, 1));pnlRow1 = new JPanel();
pnlRow2 = new JPanel();
pnlRow3 = new JPanel();
pnlRow4 = new JPanel();
pnlRow5 = new JPanel();
pnlRow6 = new JPanel();
pnlRow7 = new JPanel();
pnlSouth1 = new JPanel();
pnlSouth2 = new JPanel();pnlRow1.setLayout(new FlowLayout(FlowLayout.LEFT));
pnlRow2.setLayout(new FlowLayout(FlowLayout.LEFT));
pnlRow3.setLayout(new FlowLayout(FlowLayout.LEFT));
pnlRow4.setLayout(new FlowLayout(FlowLayout.LEFT));
pnlRow5.setLayout(new FlowLayout(FlowLayout.LEFT));
pnlRow6.setLayout(new FlowLayout(FlowLayout.LEFT));
pnlRow7.setLayout(new FlowLayout(FlowLayout.LEFT));lblId = new JLabel(“学号:”);
lblName = new JLabel(“姓名:”);
lblSex = new JLabel(“性别:”);
lblAge = new JLabel(“年龄:”);
lblDepartment = new JLabel(“系部:”);
lblClass = new JLabel(“班级:”);
lblTelephone = new JLabel(“电话:”);txtId = new JTextField(40);
txtName = new JTextField(40);
txtSex = new JTextField(40);
txtAge = new JTextField(40);
txtDepartment = new JTextField(40);
txtClass = new JTextField(40);
txtTelephone = new JTextField(40);
txtId.setEditable(false);
txtName.setEditable(false);
txtSex.setEditable(false);
txtAge.setEditable(false);
txtDepartment.setEditable(false);
txtClass.setEditable(false);
txtTelephone.setEditable(false);btnTop = new JButton(“第一条[T]”);
btnPrevious = new JButton(“上一条[P]”);
btnNext = new JButton(“下一条[N]”);
btnBottom = new JButton(“最后一条[B]”);
btnExit = new JButton(“退出[X]”);
btnEdit = new JButton(“编辑[E]”);
btnOK = new JButton(“确定[O]”);
btnCancel = new JButton(“取消[C]”);
btnOK.setEnabled(false);
btnCancel.setEnabled(false);
btnTop.setMnemonic(KeyEvent.VK_T);
btnPrevious.setMnemonic(KeyEvent.VK_P);
btnNext.setMnemonic(KeyEvent.VK_N);
btnBottom.setMnemonic(KeyEvent.VK_B);
btnExit.setMnemonic(KeyEvent.VK_X);
btnEdit.setMnemonic(KeyEvent.VK_E);
btnOK.setMnemonic(KeyEvent.VK_O);
btnCancel.setMnemonic(KeyEvent.VK_C);// 添加组件
panel.setLayout(new BorderLayout());
panel.add(pnlCenter, BorderLayout.CENTER);
panel.add(pnlSouth, BorderLayout.SOUTH);
pnlCenter.setLayout(new GridLayout(7, 1));pnlCenter.add(pnlRow1);
pnlCenter.add(pnlRow2);
pnlCenter.add(pnlRow3);
pnlCenter.add(pnlRow4);
pnlCenter.add(pnlRow5);
pnlCenter.add(pnlRow6);
pnlCenter.add(pnlRow7);pnlRow1.add(lblId);
pnlRow1.add(txtId);
pnlRow2.add(lblName);
pnlRow2.add(txtName);
pnlRow3.add(lblSex);
pnlRow3.add(txtSex);
pnlRow4.add(lblAge);
pnlRow4.add(txtAge);
pnlRow5.add(lblDepartment);
pnlRow5.add(txtDepartment);
pnlRow6.add(lblClass);
pnlRow6.add(txtClass);
pnlRow7.add(lblTelephone);
pnlRow7.add(txtTelephone);pnlSouth.add(pnlSouth1);
pnlSouth.add(pnlSouth2);
pnlSouth1.add(btnTop);
pnlSouth1.add(btnPrevious);
pnlSouth1.add(btnNext);
pnlSouth1.add(btnBottom);
pnlSouth1.add(btnExit);
pnlSouth2.add(btnEdit);
pnlSouth2.add(btnOK);
pnlSouth2.add(btnCancel);// 设置窗口属性
setSize(500, 300);
// 设置窗口不可调整大小
setResizable(false);
// 设置窗口刚好容纳组件
pack();
// 设置窗口屏幕居中
setLocationRelativeTo(null);
// 设置窗口可见
setVisible(true);
// 设置窗口默认关闭操作
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);// 创建学生服务对象
studentService = new StudentServiceImpl();
// 获取全部学生列表
students = studentService.findAllStudents();
// 判断是否有学生记录
if (students.size() > 0) {
// 设置当前记录号
currentRow = 1;
// 设置窗口标题
setTitle(“浏览学生表记录” + " && 当前记录:" + currentRow);
// 填充窗口各文本框数据
fillFrameData(currentRow);
} else {
JOptionPane.showMessageDialog(null, “表中没有记录!”, “浏览学生表记录”, JOptionPane.ERROR_MESSAGE);
btnTop.setEnabled(false);
btnPrevious.setEnabled(false);
btnNext.setEnabled(false);
btnBottom.setEnabled(false);
}// 【第一条】按钮单击事件
btnTop.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
// 设置当前记录号
currentRow = 1;
// 填充当前记录数据
fillFrameData(currentRow);
}
});// 【上一条】按钮单击事件
btnPrevious.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
if (currentRow > 1) {
// 设置当前记录号
currentRow–;
// 填充当前记录数据
fillFrameData(currentRow);
} else {
JOptionPane.showMessageDialog(null, “已到第一条记录!”, “浏览学生表记录”, JOptionPane.WARNING_MESSAGE);
}
}
});// 【下一条】按钮单击事件
btnNext.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
if (currentRow < students.size() - 1) {
// 设置当前记录号
currentRow++;
// 填充当前记录数据
fillFrameData(currentRow);
} else {
JOptionPane.showMessageDialog(null, “已到最后一条记录!”, “浏览学生表记录”, JOptionPane.WARNING_MESSAGE);
}
}
});// 【最后一条】按钮单击事件
btnBottom.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
// 设置当前记录号
currentRow = students.size() - 1;
// 填充当前记录数据
fillFrameData(currentRow);
}
});// 【退出】按钮单击事件
btnExit.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
dispose();
}
});// 【编辑】按钮单击事件
btnEdit.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
// 设置窗口标题
setTitle(“编辑学生表记录” + " && 当前记录:" + currentRow);txtName.setEditable(true); txtSex.setEditable(true); txtAge.setEditable(true); txtDepartment.setEditable(true); txtClass.setEditable(true); txtTelephone.setEditable(true); btnOK.setEnabled(true); btnCancel.setEnabled(true); }
});
// 【确定】按钮单击事件
btnOK.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
// 获取当前学生实体
Student student = students.get(currentRow);if (isNumber(txtAge.getText())) { if (isLegalTelephone(txtTelephone.getText())) { // 修改学生实体属性 student.setName(txtName.getText()); student.setSex(txtSex.getText()); student.setAge(Integer.parseInt(txtAge.getText())); student.setDepartment(txtDepartment.getText()); student.setClazz(txtClass.getText()); student.setTelephone(txtTelephone.getText()); // 更新学生信息 int count = studentService.updateStudent(student); // 判断是否更新成功 if (count > 0) { JOptionPane.showMessageDialog(null, "更新记录成功!", "编辑学生记录", JOptionPane.INFORMATION_MESSAGE); btnOK.setEnabled(false); btnCancel.setEnabled(false); btnEdit.setEnabled(true); txtName.setEditable(false); txtSex.setEditable(false); txtAge.setEditable(false); txtDepartment.setEditable(false); txtClass.setEditable(false); txtTelephone.setEditable(false); // 重新获取全部学生列表 students = studentService.findAllStudents(); // 设置窗口标题 setTitle("浏览学生表记录" + " && 当前记录:" + currentRow); } else { JOptionPane.showMessageDialog(null, "更新记录失败!", "编辑学生记录", JOptionPane.ERROR_MESSAGE); } } else { JOptionPane.showMessageDialog(null, "非法手机号!", "编辑学生记录", JOptionPane.ERROR_MESSAGE); txtTelephone.selectAll(); txtTelephone.requestFocus(); } } else { JOptionPane.showMessageDialog(null, "年龄必须是数字!", "编辑学生记录", JOptionPane.ERROR_MESSAGE); txtAge.selectAll(); txtAge.requestFocus(); } }
});
// 【取消】按钮单击事件
btnCancel.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
btnOK.setEnabled(false);
btnCancel.setEnabled(false);
btnEdit.setEnabled(true);
txtName.setEditable(false);
txtSex.setEditable(false);
txtAge.setEditable(false);
txtDepartment.setEditable(false);
txtClass.setEditable(false);
txtTelephone.setEditable(false);
// 恢复文本框修改前的值
txtName.setText(students.get(currentRow).getName());
txtSex.setText(students.get(currentRow).getSex());
txtAge.setText(students.get(currentRow).getAge() + “”);
txtDepartment.setText(students.get(currentRow).getDepartment());
txtClass.setText(students.get(currentRow).getClazz());
txtTelephone.setText(students.get(currentRow).getTelephone());
}
});// 【学号】文本框按键事件
txtId.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ENTER) {
txtName.requestFocus();
}
}
});// 【姓名】文本框按键事件
txtName.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ENTER) {
txtSex.requestFocus();
}
}
});// 【性别】文本框按键事件
txtSex.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ENTER) {
txtAge.requestFocus();
}
}
});// 【年龄】文本框按键事件
txtAge.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ENTER) {
txtDepartment.requestFocus();
}
}
});// 【系部】文本框按键事件
txtDepartment.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ENTER) {
txtClass.requestFocus();
}
}
});// 【班级】文本框按键事件
txtClass.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ENTER) {
txtTelephone.requestFocus();
}
}
});
}
/**
- 将当前记录数据填充窗口各文本框
- @param currentRow
*/
private void fillFrameData(int currentRow) {
if (currentRow > 0) {
setTitle(“浏览学生表记录” + " && 当前记录:" + currentRow);
txtId.setText(students.get(currentRow).getId());
txtName.setText(students.get(currentRow).getName());
txtSex.setText(students.get(currentRow).getSex());
txtAge.setText(students.get(currentRow).getAge() + “”);
txtDepartment.setText(students.get(currentRow).getDepartment());
txtClass.setText(students.get(currentRow).getClazz());
txtTelephone.setText(students.get(currentRow).getTelephone());
}
}
// 判断一个字符串是否全是数字
private boolean isNumber(String str) {
for (int i = 0; i < str.length(); i++) {
if (str.charAt(i) < ‘0’ || str.charAt(i) > ‘9’) {
return false;
}
}
return true;
}/**
- 判断是否合法手机号
- @param telephone
- @return
*/
private boolean isLegalTelephone(String telephone) {
Pattern p = Pattern.compile("((13[0-9])|(15[4,\D])|(18[0-9]))\d{8}$");
Matcher m = p.matcher(telephone);
return m.matches();
}
/**
- 主方法
- @param args
*/
public static void main(String[] args) {
new EditStudentFrame("");
}
- 声明面板
}
11.运行结果如下:
二、创建一个类按学号删除学生记录
1.DeleteStudentByIdFrame
2.先是构造方法、主方法、初始化界面、标签、文本框、面板、按钮、记录行集、表格列标题、滚动面板、学生列表、创建学生服务对象、组件、添加组件、创建标题边框对象、创建学生服务对象、获取全部学生列表、填充表格数据、设置窗口大小、设置窗口屏幕居中、单击事件、按键事件。
package net.zxk.student.gui;
/**
- 功能:按学号删除学生记录
- 作者:周许苛
- 日期:2019年6月22日
*/
import net.zxk.student.bean.Student;
import net.zxk.student.service.StudentService;
import net.zxk.student.service.impl.StudentServiceImpl;
import javax.swing.;
import javax.swing.border.TitledBorder;
import java.awt.;
import java.awt.event.*;
import java.util.Vector;
import java.util.List;
public class DeleteStudentByIdFrame extends JFrame {
/**
* 学号标签
/
private JLabel lblInputId;
/*
* 学号文本框
/
private JTextField txtId;
/*
* 面板
*/
private JPanel panel;
private JPanel pnlSouth;
private JPanel pnlCenter;
private JPanel pnlNorth;
/**
* 按钮
*/
private JButton btnQuery;
private JButton btnBrowseAll;
private JButton btnDelete;
private JButton btnExit;
/**
* 记录行集
*/
private Vector rows;
/**
* 表格列标题
*/
private Vector<String> colHead;
/**
* 表格
*/
private JTable table;
/**
* 滚动面板
*/
private JScrollPane scroller;
/**
* 当前记录行号
*/
private int currentRow;
/**
* 学生列表
*/
private List<Student> students;
/**
* 创建学生服务对象
*/
private StudentService studentService;
/**
* 构造方法
*
* @param title
*/
public DeleteStudentByIdFrame(String title) {
super(title);
intiGUI();
}
private void intiGUI() {
// 创建组件
panel = (JPanel) getContentPane();
pnlNorth = new JPanel();
pnlCenter = new JPanel();
pnlSouth = new JPanel();
rows = new Vector();
colHead = new Vector();
lblInputId = new JLabel("输入学号:");
txtId = new JTextField(10);
txtId.setHorizontalAlignment(JTextField.CENTER);
btnQuery = new JButton("查询[Q]");
btnQuery.setMnemonic(KeyEvent.VK_Q);
btnBrowseAll = new JButton("显示全部记录[A]");
btnBrowseAll.setMnemonic(KeyEvent.VK_A);
btnDelete = new JButton("删除查询的记录[D]");
btnDelete.setEnabled(false);// 删除按钮不可用
btnDelete.setMnemonic(KeyEvent.VK_D);
btnExit = new JButton("退出[X]");
btnExit.setMnemonic(KeyEvent.VK_X);
// 添加组件
panel.add(pnlSouth, BorderLayout.SOUTH);
panel.add(pnlCenter, BorderLayout.CENTER);
panel.add(pnlNorth, BorderLayout.NORTH);
pnlNorth.add(lblInputId);
pnlNorth.add(txtId);
pnlNorth.add(btnQuery);
pnlNorth.add(btnBrowseAll);
pnlSouth.setLayout(new FlowLayout(FlowLayout.RIGHT));
pnlSouth.add(btnDelete);
pnlSouth.add(btnExit);
pnlCenter.setLayout(new BorderLayout());
// 创建标题边框对象
TitledBorder tb = new TitledBorder("查询结果");
pnlCenter.setBorder(tb);
// 创建学生服务对象
studentService = new StudentServiceImpl();
// 获取全部学生列表
students = studentService.findAllStudents();
// 填充表格数据
fillTableData();
// 设置窗口大小
setSize(600, 350);
// 设置窗口不可调整大小
setResizable(false);
// 设置窗口屏幕居中
setLocationRelativeTo(null);
// 设置窗口标题
setTitle("按学号删除学生记录");
// 设置窗口可见
setVisible(true);
// 设置窗口默认关闭操作
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
// 【退出】按钮单击事件
btnExit.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
dispose();
}
});
// 【删除】按钮单击事件
btnDelete.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
if (!rows.isEmpty()) {
long choice = JOptionPane.showConfirmDialog(null, "是否要删除记录?");
if (choice == JOptionPane.OK_OPTION) {
// 获取待删学生学号
String id = txtId.getText().trim();
// 按学号删除学生
int count = studentService.deleteStudentById(id);
if (count > 0) {
JOptionPane.showMessageDialog(null, "记录删除成功!", "提示", JOptionPane.INFORMATION_MESSAGE);
// 重新获取全部学生列表
students = studentService.findAllStudents();
// 清空待删学生学号文本框
txtId.setText("");
// 填充数据
fillTableData();
// 删除按钮不可用
btnDelete.setEnabled(false);
} else {
JOptionPane.showMessageDialog(null, "记录删除失败!", "警告", JOptionPane.WARNING_MESSAGE);
}
}
}
}
});
// 【查询】按钮单击事件
btnQuery.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
doQuery();
}
});
// 【显示全部记录】按钮单击事件
btnBrowseAll.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
// 获取全部学生记录
students = studentService.findAllStudents();
// 填充表格数据
fillTableData();
// 删除按钮不可用
btnDelete.setEnabled(false);
}
});
// 【学号】文本框按键事件
txtId.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ENTER) {
doQuery();
}
}
});
// 表格单击事件
table.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
// 获取当前行的行数
int row = table.rowAtPoint(e.getPoint());
// 选中鼠标单击的行
table.setRowSelectionInterval(row, row);
// 设置文本框内容
txtId.setText(table.getValueAt(row, 0).toString());
}
});
}
/**
* 查询方法
*/
private void doQuery() {
// 获取查询学号
String id = txtId.getText().trim();
if (!id.equals("")) {
students.clear();
Student student = studentService.findStudentById(id);
if (student != null) {
// 将查询到的学生添加到列表
students.add(student);
// 让删除按钮可用
btnDelete.setEnabled(true);
}
// 填充表格
fillTableData();
} else {
JOptionPane.showMessageDialog(this, "请输入待查学生学号!", "警告", JOptionPane.WARNING_MESSAGE);
txtId.requestFocus();
}
}
/**
* 填充表格方法
*/
private void fillTableData() {
// 填充表头
colHead.clear();
colHead.add("学号");
colHead.add("姓名");
colHead.add("性别");
colHead.add("年龄");
colHead.add("系部");
colHead.add("班级");
colHead.add("电话");
// 填充表记录
rows.clear();
for (Student student : students) {
Vector<String> currentRow = new Vector<String>();
currentRow.addElement(student.getId());
currentRow.addElement(student.getName());
currentRow.addElement(student.getSex());
currentRow.addElement(student.getAge() + "");
currentRow.addElement(student.getDepartment());
currentRow.addElement(student.getClazz());
currentRow.addElement(student.getTelephone());
// 将当前行添加到记录行集
rows.add(currentRow);
}
// 创建表格(参数1:记录集;参数2:表头)
table = new JTable(rows, colHead);
// 定义滚动面板
scroller = new JScrollPane(table, JScrollPane.VERTICAL_SCROLLBAR_AS_NEEDED,
JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
// 将滚动面板添加到中心面板
pnlCenter.add(scroller, BorderLayout.CENTER);
// 重绘窗体
repaint();
// 判断是否有记录行
if (rows.isEmpty()) {
JOptionPane.showMessageDialog(this, "没有符合条件的记录!", "错误提示", JOptionPane.WARNING_MESSAGE);
txtId.setText("");
} else {
// 让滚动条移到最上方
scroller.getVerticalScrollBar().setValue(0);
}
}
/**
* 主方法
*
* @param args
*/
public static void main(String[] args) {
new DeleteStudentByIdFrame("");
}
}
运行结果如下:
三、创建一个类按班级删除学生的记录
DeleteStudentsByClassFrame
3.先是构造方法、主方法、初始化界面、标签、文本框、面板、按钮、记录行集、表格列标题、滚动面板、学生列表、创建学生服务对象、组件、添加组件、创建标题边框对象、创建学生服务对象、获取全部学生列表、填充表格数据、设置窗口大小、设置窗口屏幕居中、单击事件、按键事件。
4.代码如下:
package net.zxk.student.gui;
import net.zxk.student.bean.Student;
import net.zxk.student.service.StudentService;
import net.zxk.student.service.impl.StudentServiceImpl;
import javax.swing.;
import javax.swing.border.TitledBorder;
import java.awt.;
import java.awt.event.*;
import java.util.Vector;
import java.util.List;
/**
- 功能:按班级删除学生记录
- 作者:周许苛
- 日期:2019年6月22日
*/
public class DeleteStudentsByClassFrame extends JFrame {
/**
* 班级标签
/
private JLabel lblInputClass;
/*
* 班级文本框
/
private JTextField txtClass;
/*
* 面板
/
private JPanel panel;
private JPanel pnlSouth;
private JPanel pnlCenter;
private JPanel pnlNorth;
/*
* 按钮
/
private JButton btnQuery;
private JButton btnBrowseAll;
private JButton btnDelete;
private JButton btnExit;
/*
* 记录行集
/
private Vector rows;
/*
* 表格列标题
/
private Vector colHead;
/*
* 表格
/
private JTable table;
/*
* 滚动面板
*/
private JScrollPane scroller;
/**
* 当前记录行号
*/
private int currentRow;
/**
* 学生列表
*/
private List<Student> students;
/**
* 创建学生服务对象
*/
private StudentService studentService;
/**
* 构造方法
*
* @param title
*/
public DeleteStudentsByClassFrame(String title) {
super(title);
intiGUI();
}
private void intiGUI() {
// 创建组件
panel = (JPanel) getContentPane();
pnlNorth = new JPanel();
pnlCenter = new JPanel();
pnlSouth = new JPanel();
rows = new Vector();
colHead = new Vector();
lblInputClass = new JLabel("输入班级:");
txtClass = new JTextField(10);
txtClass.setHorizontalAlignment(JTextField.CENTER);
btnQuery = new JButton("查询[Q]");
btnQuery.setMnemonic(KeyEvent.VK_Q);
btnBrowseAll = new JButton("显示全部记录[A]");
btnBrowseAll.setMnemonic(KeyEvent.VK_A);
btnDelete = new JButton("删除查询的记录[D]");
btnDelete.setEnabled(false);// 删除按钮不可用
btnDelete.setMnemonic(KeyEvent.VK_D);
btnExit = new JButton("退出[X]");
btnExit.setMnemonic(KeyEvent.VK_X);
// 添加组件
panel.add(pnlSouth, BorderLayout.SOUTH);
panel.add(pnlCenter, BorderLayout.CENTER);
panel.add(pnlNorth, BorderLayout.NORTH);
pnlNorth.add(lblInputClass);
pnlNorth.add(txtClass);
pnlNorth.add(btnQuery);
pnlNorth.add(btnBrowseAll);
pnlSouth.setLayout(new FlowLayout(FlowLayout.RIGHT));
pnlSouth.add(btnDelete);
pnlSouth.add(btnExit);
pnlCenter.setLayout(new BorderLayout());
// 创建标题边框对象
TitledBorder tb = new TitledBorder("查询结果");
pnlCenter.setBorder(tb);
// 创建学生服务对象
studentService = new StudentServiceImpl();
// 获取全部学生列表
students = studentService.findAllStudents();
// 填充表格数据
fillTableData();
// 设置窗口大小
setSize(600, 350);
// 设置窗口不可调整大小
setResizable(false);
// 设置窗口屏幕居中
setLocationRelativeTo(null);
// 设置窗口标题
setTitle("按班级删除学生记录");
// 设置窗口可见
setVisible(true);
// 设置窗口默认关闭操作
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
// 【退出】按钮单击事件
btnExit.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
dispose();
}
});
// 【删除】按钮单击事件
btnDelete.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
if (!rows.isEmpty()) {
long choice = JOptionPane.showConfirmDialog(null, "是否要删除记录?");
if (choice == JOptionPane.OK_OPTION) {
// 获取待删班级
String clazz = txtClass.getText().trim();
// 按班级删除学生
int count = studentService.deleteStudentsByClass(clazz);
if (count > 0) {
JOptionPane.showMessageDialog(null, "记录删除成功!", "提示", JOptionPane.INFORMATION_MESSAGE);
// 重新获取全部学生列表
students = studentService.findAllStudents();
// 清空待删班级文本框
txtClass.setText("");
// 填充数据
fillTableData();
// 删除按钮不可用
btnDelete.setEnabled(false);
} else {
JOptionPane.showMessageDialog(null, "记录删除失败!", "警告", JOptionPane.WARNING_MESSAGE);
}
}
}
}
});
// 【查询】按钮单击事件
btnQuery.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
doQuery();
}
});
// 【显示全部记录】按钮单击事件
btnBrowseAll.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
// 获取全部学生记录
students = studentService.findAllStudents();
// 填充表格数据
fillTableData();
// 删除按钮不可用
btnDelete.setEnabled(false);
}
});
// 【班级】文本框按键事件
txtClass.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ENTER) {
doQuery();
}
}
});
// 表格单击事件
table.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
// 获取当前行的行数
int row = table.rowAtPoint(e.getPoint());
// 选中鼠标单击的行
table.setRowSelectionInterval(row, row);
// 设置文本框内容
txtClass.setText(table.getValueAt(row, 5).toString());
}
});
}
/**
* 查询方法
*/
private void doQuery() {
// 获取查询班级
String clazz = txtClass.getText().trim();
if (!clazz.equals("")) {
students = studentService.findStudentsByClass(clazz);
if (students.size() > 0) {
// 让删除按钮可用
btnDelete.setEnabled(true);
}
// 填充表格
fillTableData();
} else {
JOptionPane.showMessageDialog(this, "请输入待查班级!", "警告", JOptionPane.WARNING_MESSAGE);
txtClass.requestFocus();
}
}
/**
* 填充表格方法
*/
private void fillTableData() {
// 填充表头
colHead.clear();
colHead.add("学号");
colHead.add("姓名");
colHead.add("性别");
colHead.add("年龄");
colHead.add("系部");
colHead.add("班级");
colHead.add("电话");
// 填充表记录
rows.clear();
for (Student student : students) {
Vector<String> currentRow = new Vector<String>();
currentRow.addElement(student.getId());
currentRow.addElement(student.getName());
currentRow.addElement(student.getSex());
currentRow.addElement(student.getAge() + "");
currentRow.addElement(student.getDepartment());
currentRow.addElement(student.getClazz());
currentRow.addElement(student.getTelephone());
// 将当前行添加到记录行集
rows.add(currentRow);
}
// 创建表格(参数1:记录集;参数2:表头)
table = new JTable(rows, colHead);
// 定义滚动面板
scroller = new JScrollPane(table, JScrollPane.VERTICAL_SCROLLBAR_AS_NEEDED,
JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
// 将滚动面板添加到中心面板
pnlCenter.add(scroller, BorderLayout.CENTER);
// 重绘窗体
repaint();
// 判断是否有记录行
if (rows.isEmpty()) {
JOptionPane.showMessageDialog(this, "没有符合条件的记录!", "错误提示", JOptionPane.WARNING_MESSAGE);
txtClass.setText("");
} else {
// 让滚动条移到最上方
scroller.getVerticalScrollBar().setValue(0);
}
}
/**
* 主方法
*
* @param args
*/
public static void main(String[] args) {
new DeleteStudentsByClassFrame("");
}
}
5.运行结果如下:
四、创建一个按系部删除学生的记录
1.DeleteStudentsByDepartmentFrame
2.先是构造方法、
3.主方法、
4.初始化界面、标签、文本框、面板、按钮、记录行集、表格列标题、滚动面板、学生列表、创建学生服务对象、组件、添加组件
5、创建标题边框对象、创建学生服务对象、获取全部学生列表、填充表格数据、设置窗口大小、设置窗口屏幕居中、
6、单击事件、按键事件。
7、查询方法、填充表格方法、填充表记录、创建表格(参数1:记录集;参数2:表头)、
9、代码如下:
package net.zxk.student.gui;
import net.zxk.student.bean.Student;
import net.zxk.student.service.StudentService;
import net.zxk.student.service.impl.StudentServiceImpl;
import javax.swing.;
import javax.swing.border.TitledBorder;
import java.awt.;
import java.awt.event.*;
import java.util.Vector;
import java.util.List;
/**
-
功能:按系部删除学生记录
-
作者:周许苛
-
日期:2019年6月22日
/
public class DeleteStudentsByDepartmentFrame extends JFrame {
/*- 系部标签
/
private JLabel lblInputDepartment;
/* - 系部文本框
/
private JTextField txtDepartment;
/* - 面板
/
private JPanel panel;
private JPanel pnlSouth;
private JPanel pnlCenter;
private JPanel pnlNorth;
/* - 按钮
/
private JButton btnQuery;
private JButton btnBrowseAll;
private JButton btnDelete;
private JButton btnExit;
/* - 记录行集
/
private Vector rows;
/* - 表格列标题
/
private Vector colHead;
/* - 表格
/
private JTable table;
/* - 滚动面板
*/
private JScrollPane scroller;
/**
- 当前记录行号
/
private int currentRow;
/* - 学生列表
/
private List students;
/* - 创建学生服务对象
*/
private StudentService studentService;
/**
- 构造方法
- @param title
*/
public DeleteStudentsByDepartmentFrame(String title) {
super(title);
intiGUI();
}
private void intiGUI() {
// 创建组件
panel = (JPanel) getContentPane();
pnlNorth = new JPanel();
pnlCenter = new JPanel();
pnlSouth = new JPanel();rows = new Vector(); colHead = new Vector(); lblInputDepartment = new JLabel("输入系部:"); txtDepartment = new JTextField(10); txtDepartment.setHorizontalAlignment(JTextField.CENTER); btnQuery = new JButton("查询[Q]"); btnQuery.setMnemonic(KeyEvent.VK_Q); btnBrowseAll = new JButton("显示全部记录[A]"); btnBrowseAll.setMnemonic(KeyEvent.VK_A); btnDelete = new JButton("删除查询的记录[D]"); btnDelete.setEnabled(false);// 删除按钮不可用 btnDelete.setMnemonic(KeyEvent.VK_D); btnExit = new JButton("退出[X]"); btnExit.setMnemonic(KeyEvent.VK_X); // 添加组件 panel.add(pnlSouth, BorderLayout.SOUTH); panel.add(pnlCenter, BorderLayout.CENTER); panel.add(pnlNorth, BorderLayout.NORTH); pnlNorth.add(lblInputDepartment); pnlNorth.add(txtDepartment); pnlNorth.add(btnQuery); pnlNorth.add(btnBrowseAll); pnlSouth.setLayout(new FlowLayout(FlowLayout.RIGHT)); pnlSouth.add(btnDelete); pnlSouth.add(btnExit); pnlCenter.setLayout(new BorderLayout()); // 创建标题边框对象 TitledBorder tb = new TitledBorder("查询结果"); pnlCenter.setBorder(tb); // 创建学生服务对象 studentService = new StudentServiceImpl(); // 获取全部学生列表 students = studentService.findAllStudents(); // 填充表格数据 fillTableData(); // 设置窗口大小 setSize(600, 350); // 设置窗口不可调整大小 setResizable(false); // 设置窗口屏幕居中 setLocationRelativeTo(null); // 设置窗口标题 setTitle("按系部删除学生记录"); // 设置窗口可见 setVisible(true); // 设置窗口默认关闭操作 setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); // 【退出】按钮单击事件 btnExit.addActionListener(new ActionListener() { @Override public void actionPerformed(ActionEvent event) { dispose(); } }); // 【删除】按钮单击事件 btnDelete.addActionListener(new ActionListener() { @Override public void actionPerformed(ActionEvent e) { if (!rows.isEmpty()) { long choice = JOptionPane.showConfirmDialog(null, "是否要删除记录?"); if (choice == JOptionPane.OK_OPTION) { // 获取待删系部 String department = txtDepartment.getText().trim(); // 按系部删除学生 int count = studentService.deleteStudentsByDepartment(department); if (count > 0) { JOptionPane.showMessageDialog(null, "记录删除成功!", "提示", JOptionPane.INFORMATION_MESSAGE); // 重新获取全部学生列表 students = studentService.findAllStudents(); // 清空待删班级文本框 txtDepartment.setText(""); // 填充数据 fillTableData(); // 删除按钮不可用 btnDelete.setEnabled(false); } else { JOptionPane.showMessageDialog(null, "记录删除失败!", "警告", JOptionPane.WARNING_MESSAGE); } } } } }); // 【查询】按钮单击事件 btnQuery.addActionListener(new ActionListener() { @Override public void actionPerformed(ActionEvent event) { doQuery(); } }); // 【显示全部记录】按钮单击事件 btnBrowseAll.addActionListener(new ActionListener() { @Override public void actionPerformed(ActionEvent event) { // 获取全部学生记录 students = studentService.findAllStudents(); // 填充表格数据 fillTableData(); // 删除按钮不可用 btnDelete.setEnabled(false); } }); // 【系部】文本框按键事件 txtDepartment.addKeyListener(new KeyAdapter() { @Override public void keyPressed(KeyEvent e) { if (e.getKeyCode() == KeyEvent.VK_ENTER) { doQuery(); } } }); // 表格单击事件 table.addMouseListener(new MouseAdapter() { public void mouseClicked(MouseEvent e) { // 获取当前行的行数 int row = table.rowAtPoint(e.getPoint()); // 选中鼠标单击的行 table.setRowSelectionInterval(row, row); // 设置文本框内容 txtDepartment.setText(table.getValueAt(row, 4).toString()); } });
}
/**
- 查询方法
*/
private void doQuery() {
// 获取查询系部
String department = txtDepartment.getText().trim();
if (!department.equals("")) {
students = studentService.findStudentsByDepartment(department);
if (students.size() > 0) {
// 让删除按钮可用
btnDelete.setEnabled(true);
}
// 填充表格
fillTableData();
} else {
JOptionPane.showMessageDialog(this, “请输入待查系部!”, “警告”, JOptionPane.WARNING_MESSAGE);
txtDepartment.requestFocus();
}
}
/**
-
填充表格方法
*/
private void fillTableData() {
// 填充表头
colHead.clear();
colHead.add(“学号”);
colHead.add(“姓名”);
colHead.add(“性别”);
colHead.add(“年龄”);
colHead.add(“系部”);
colHead.add(“班级”);
colHead.add(“电话”);// 填充表记录
rows.clear();
for (Student student : students) {
Vector currentRow = new Vector();
currentRow.addElement(student.getId());
currentRow.addElement(student.getName());
currentRow.addElement(student.getSex());
currentRow.addElement(student.getAge() + “”);
currentRow.addElement(student.getDepartment());
currentRow.addElement(student.getClazz());
currentRow.addElement(student.getTelephone());
// 将当前行添加到记录行集
rows.add(currentRow);
}// 创建表格(参数1:记录集;参数2:表头)
table = new JTable(rows, colHead);// 定义滚动面板
scroller = new JScrollPane(table, JScrollPane.VERTICAL_SCROLLBAR_AS_NEEDED,
JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
// 将滚动面板添加到中心面板
pnlCenter.add(scroller, BorderLayout.CENTER);// 重绘窗体
repaint();// 判断是否有记录行
if (rows.isEmpty()) {
JOptionPane.showMessageDialog(this, “没有符合条件的记录!”, “错误提示”, JOptionPane.WARNING_MESSAGE);
txtDepartment.setText("");
} else {
// 让滚动条移到最上方
scroller.getVerticalScrollBar().setValue(0);
}
}
/**
- 主方法
- @param args
*/
public static void main(String[] args) {
new DeleteStudentsByDepartmentFrame("");
}
}
- 系部标签
10、运行结果如下:
五、创建一个按学号查询学生记录
1.FindStudentByIdFrame
2、先是构造方法,
3、然后再是主方法、
4、初始化用户界面、
5、按学号标签、学号文本框、面板、按钮、
6、记录行集、滚动面板、表格、当前记录号、创建学生服务对象。
7、退出按钮单击事件、打印按钮单击事件、查询按钮单击事件、显示全部记录按钮单击事件
8.学号文本框按键事件、表格单击事件、获取当前的行数、选中鼠标单击的行、查询方法、获取查询号、将查到的学生添加到列表。
11.填充表格的方法填充表记录、将当前行添加到记录行集、创建表格、定义滚定面板、将滚动面板添加到中心面板中去。
12.代码如下:
package net.zxk.student.gui;
import net.zxk.student.bean.Student;
import net.zxk.student.service.StudentService;
import net.zxk.student.service.impl.StudentServiceImpl;
import javax.swing.;
import javax.swing.border.TitledBorder;
import java.awt.;
import java.awt.event.*;
import java.awt.print.PrinterException;
import java.util.Vector;
import java.util.List;
/**
- 功能:按学号查询学生的记录
- 作者:周许苛
- 日期:2019年6月22日
*/
public class FindStudentByIdFrame extends JFrame {
/**
* 学号标签
/
private JLabel lblInputId;
/*
* 学号文本框
/
private JTextField txtId;
/*
* 面板
/
private JPanel panel;
private JPanel pnlSouth;
private JPanel pnlCenter;
private JPanel pnlNorth;
/*
* 按钮
/
private JButton btnQuery;
private JButton btnBrowseAll;
private JButton btnPrint;
private JButton btnExit;
/*
* 记录行集
/
private Vector rows;
/*
* 表格列标题
/
private Vector colHead;
/*
* 表格
/
private JTable table;
/*
* 滚动面板
/
private JScrollPane scroller;
/*
* 当前记录行号
/
private int currentRow;
/*
* 学生列表
/
private List students;
/*
* 创建学生服务对象
*/
private StudentService studentService;
/**
* 构造方法
*
* @param title
*/
public FindStudentByIdFrame(String title) {
super(title);
intiGUI();
}
/**
* 初始化用户界面
*/
private void intiGUI() {
// 创建组件
panel = (JPanel) getContentPane();
pnlNorth = new JPanel();
pnlCenter = new JPanel();
pnlSouth = new JPanel();
rows = new Vector();
colHead = new Vector();
lblInputId = new JLabel("输入学号:");
txtId = new JTextField(10);
txtId.setHorizontalAlignment(JTextField.CENTER);
btnQuery = new JButton("查询[Q]");
btnQuery.setMnemonic(KeyEvent.VK_Q);
btnBrowseAll = new JButton("显示全部记录[A]");
btnBrowseAll.setMnemonic(KeyEvent.VK_A);
btnPrint = new JButton("打印[P]");
btnPrint.setMnemonic(KeyEvent.VK_D);
btnExit = new JButton("退出[X]");
btnExit.setMnemonic(KeyEvent.VK_X);
// 添加组件
panel.add(pnlSouth, BorderLayout.SOUTH);
panel.add(pnlCenter, BorderLayout.CENTER);
panel.add(pnlNorth, BorderLayout.NORTH);
pnlNorth.add(lblInputId);
pnlNorth.add(txtId);
pnlNorth.add(btnQuery);
pnlNorth.add(btnBrowseAll);
pnlSouth.setLayout(new FlowLayout(FlowLayout.RIGHT));
pnlSouth.add(btnPrint);
pnlSouth.add(btnExit);
pnlCenter.setLayout(new BorderLayout());
// 创建标题边框对象
TitledBorder tb = new TitledBorder("查询结果");
pnlCenter.setBorder(tb);
// 创建学生服务对象
studentService = new StudentServiceImpl();
// 获取全部学生列表
students = studentService.findAllStudents();
// 填充表格数据
fillTableData();
// 设置窗口大小
setSize(600, 350);
// 设置窗口不可调整大小
setResizable(false);
// 设置窗口屏幕居中
setLocationRelativeTo(null);
// 设置窗口标题
setTitle("按学号查询学生记录");
// 设置窗口可见
setVisible(true);
// 设置窗口默认关闭操作
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
// 【退出】按钮单击事件
btnExit.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
dispose();
}
});
// 【打印】按钮单击事件
btnPrint.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
try {
table.print();
} catch (PrinterException e1) {
e1.printStackTrace();
}
}
});
// 【查询】按钮单击事件
btnQuery.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
doQuery();
}
});
// 【显示全部记录】按钮单击事件
btnBrowseAll.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
// 获取全部学生记录
students = studentService.findAllStudents();
// 填充表格数据
fillTableData();
// 删除按钮不可用
btnPrint.setEnabled(false);
}
});
// 【学号】文本框按键事件
txtId.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ENTER) {
doQuery();
}
}
});
// 表格单击事件
table.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
// 获取当前行的行数
int row = table.rowAtPoint(e.getPoint());
// 选中鼠标单击的行
table.setRowSelectionInterval(row, row);
// 设置文本框内容
txtId.setText(table.getValueAt(row, 0).toString());
}
});
}
/**
* 查询方法
*/
private void doQuery() {
// 获取查询学号
String id = txtId.getText().trim();
if (!id.equals("")) {
students.clear();
Student student = studentService.findStudentById(id);
if (student != null) {
// 将查询到的学生添加到列表
students.add(student);
}
// 填充表格
fillTableData();
} else {
JOptionPane.showMessageDialog(this, "请输入待查学生学号!", "警告", JOptionPane.WARNING_MESSAGE);
txtId.requestFocus();
}
}
/**
* 填充表格方法
*/
private void fillTableData() {
// 填充表头
colHead.clear();
colHead.add("学号");
colHead.add("姓名");
colHead.add("性别");
colHead.add("年龄");
colHead.add("系部");
colHead.add("班级");
colHead.add("电话");
// 填充表记录
rows.clear();
for (Student student : students) {
Vector<String> currentRow = new Vector<String>();
currentRow.addElement(student.getId());
currentRow.addElement(student.getName());
currentRow.addElement(student.getSex());
currentRow.addElement(student.getAge() + "");
currentRow.addElement(student.getDepartment());
currentRow.addElement(student.getClazz());
currentRow.addElement(student.getTelephone());
// 将当前行添加到记录行集
rows.add(currentRow);
}
// 创建表格(参数1:记录集;参数2:表头)
table = new JTable(rows, colHead);
// 定义滚动面板
scroller = new JScrollPane(table, JScrollPane.VERTICAL_SCROLLBAR_AS_NEEDED,
JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
// 将滚动面板添加到中心面板
pnlCenter.add(scroller, BorderLayout.CENTER);
// 重绘窗体
repaint();
// 判断是否有记录行
if (rows.isEmpty()) {
JOptionPane.showMessageDialog(this, "没有符合条件的记录!", "错误提示", JOptionPane.WARNING_MESSAGE);
txtId.setText("");
} else {
// 让滚动条移到最上方
scroller.getVerticalScrollBar().setValue(0);
}
}
/**
* 主方法
*
* @param args
*/
public static void main(String[] args) {
new FindStudentByIdFrame("");
}
}
13.运行结果如下:
五、创建一个按姓名查找的类
FindStudentsByNameFrame
1.
2.退出按钮单击事件、打印按钮单击事件、查询按钮单击事件
3.
显示全部记录按钮单击事件、文本框按键事件、表格单击事件、填充表格方法、填充记录方法。
4.代码如下:
package net.zxk.student.gui;
import net.zxk.student.bean.Student;
import net.zxk.student.service.StudentService;
import net.zxk.student.service.impl.StudentServiceImpl;
import javax.swing.;
import javax.swing.border.TitledBorder;
import java.awt.;
import java.awt.event.*;
import java.awt.print.PrinterException;
import java.util.Vector;
import java.util.List;
/**
-
功能:按姓名查找
-
作者:周许苛
-
日期:2019年6月22日
/
public class FindStudentsByNameFrame extends JFrame {
/*- 姓名标签
/
private JLabel lblInputName;
/* - 姓名文本框
*/
private JTextField txtName;
/**
- 面板
*/
private JPanel panel;
private JPanel pnlSouth;
private JPanel pnlCenter;
private JPanel pnlNorth;
/**
- 按钮
*/
private JButton btnQuery;
private JButton btnBrowseAll;
private JButton btnPrint;
private JButton btnExit;
/**
- 记录行集
/
private Vector rows;
/* - 表格列标题
/
private Vector colHead;
/* - 表格
/
private JTable table;
/* - 滚动面板
*/
private JScrollPane scroller;
/**
- 当前记录行号
/
private int currentRow;
/* - 学生列表
/
private List students;
/* - 创建学生服务对象
*/
private StudentService studentService;
/**
- 构造方法
- @param title
*/
public FindStudentsByNameFrame(String title) {
super(title);
intiGUI();
}
/**
-
初始化用户界面
*/
private void intiGUI() {
// 创建对象
panel = (JPanel) getContentPane();
pnlNorth = new JPanel();
pnlCenter = new JPanel();
pnlSouth = new JPanel();rows = new Vector();
colHead = new Vector();lblInputName = new JLabel(“输入姓名:”);
txtName = new JTextField(10);
txtName.setHorizontalAlignment(JTextField.CENTER);
btnQuery = new JButton(“查询[Q]”);
btnQuery.setMnemonic(KeyEvent.VK_Q);
btnBrowseAll = new JButton(“显示全部记录[A]”);
btnBrowseAll.setMnemonic(KeyEvent.VK_A);
btnPrint = new JButton(“打印[P]”);
btnPrint.setMnemonic(KeyEvent.VK_D);
btnExit = new JButton(“退出[X]”);
btnExit.setMnemonic(KeyEvent.VK_X);// 添加组件
panel.add(pnlSouth, BorderLayout.SOUTH);
panel.add(pnlCenter, BorderLayout.CENTER);
panel.add(pnlNorth, BorderLayout.NORTH);pnlNorth.add(lblInputName);
pnlNorth.add(txtName);
pnlNorth.add(btnQuery);
pnlNorth.add(btnBrowseAll);
pnlSouth.setLayout(new FlowLayout(FlowLayout.RIGHT));
pnlSouth.add(btnPrint);
pnlSouth.add(btnExit);
pnlCenter.setLayout(new BorderLayout());// 创建标题边框对象
TitledBorder tb = new TitledBorder(“查询结果”);
pnlCenter.setBorder(tb);// 创建学生服务对象
studentService = new StudentServiceImpl();
// 获取全部学生列表
students = studentService.findAllStudents();
// 填充表格数据
fillTableData();// 设置窗口大小
setSize(600, 350);
// 设置窗口不可调整大小
setResizable(false);
// 设置窗口屏幕居中
setLocationRelativeTo(null);
// 设置窗口标题
setTitle(“按姓名查询学生记录”);
// 设置窗口可见
setVisible(true);
// 设置窗口默认关闭操作
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);// 【退出】按钮单击事件
btnExit.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
dispose();
}
});// 【打印】按钮单击事件
btnPrint.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
try {
table.print();
} catch (PrinterException e1) {
e1.printStackTrace();
}
}
});// 【查询】按钮单击事件
btnQuery.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
doQuery();
}
});// 【显示全部记录】按钮单击事件
btnBrowseAll.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
// 获取全部学生记录
students = studentService.findAllStudents();
// 填充表格数据
fillTableData();
}
});// 【姓名】文本框按键事件
txtName.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ENTER) {
doQuery();
}
}
});// 表格单击事件
table.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
// 获取当前行的行数
int row = table.rowAtPoint(e.getPoint());
// 选中鼠标单击的行
table.setRowSelectionInterval(row, row);
// 设置文本框内容
txtName.setText(table.getValueAt(row, 1).toString());
}
});
}
/**
- 查询方法
*/
private void doQuery() {
// 获取查询姓名
String name = txtName.getText().trim();
if (!name.equals("")) {
// 按姓名查询获取学生列表
students = studentService.findStudentsByName(name);
// 填充表格
fillTableData();
} else {
JOptionPane.showMessageDialog(this, “请输入待查学生姓名!”, “警告”, JOptionPane.WARNING_MESSAGE);
txtName.requestFocus();
}
}
/**
-
填充表格方法
*/
private void fillTableData() {
// 填充表头
colHead.clear();
colHead.add(“姓名”);
colHead.add(“姓名”);
colHead.add(“性别”);
colHead.add(“年龄”);
colHead.add(“系部”);
colHead.add(“班级”);
colHead.add(“电话”);// 填充表记录
rows.clear();
for (Student student : students) {
Vector currentRow = new Vector();
currentRow.addElement(student.getId());
currentRow.addElement(student.getName());
currentRow.addElement(student.getSex());
currentRow.addElement(student.getAge() + “”);
currentRow.addElement(student.getDepartment());
currentRow.addElement(student.getClazz());
currentRow.addElement(student.getTelephone());
// 将当前行添加到记录行集
rows.add(currentRow);
}// 创建表格(参数1:记录集;参数2:表头)
table = new JTable(rows, colHead);// 定义滚动面板
scroller = new JScrollPane(table, JScrollPane.VERTICAL_SCROLLBAR_AS_NEEDED,
JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
// 将滚动面板添加到中心面板
pnlCenter.add(scroller, BorderLayout.CENTER);// 重绘窗体
repaint();// 判断是否有记录行
if (rows.isEmpty()) {
JOptionPane.showMessageDialog(this, “没有符合条件的记录!”, “错误提示”, JOptionPane.WARNING_MESSAGE);
txtName.setText("");
} else {
// 让滚动条移到最上方
scroller.getVerticalScrollBar().setValue(0);
}
}
/**
- 主方法
- @param args
*/
public static void main(String[] args) {
new FindStudentsByNameFrame("");
}
}
- 姓名标签
5.运行结果如下:
六、创建一个按班级查询学生记录
FindStudentsByClassFrame
1.
2.先是构造方法、主方法。
3.初始化用户界面:
4.添加班级标签、班级文本框、面板、按钮、记录行集、表格列标题、表格、
5.滚动面板、当前记录行号、创建学生服务对象。
6.添加组件、创建标题边框对象、创建学生服务对象、获取全部学生的列表、设置窗口的各种属性。
7.退出按钮单击事件、打印按钮单击事件、显示全部按钮单击事件。
8.文本框按键事件、表格单击事件、查询方法填充表格方法。
9。代码如下:
package net.zxk.student.gui;
import net.zxk.student.bean.Student;
import net.zxk.student.service.StudentService;
import net.zxk.student.service.impl.StudentServiceImpl;
import javax.swing.;
import javax.swing.border.TitledBorder;
import java.awt.;
import java.awt.event.*;
import java.awt.print.PrinterException;
import java.util.Vector;
import java.util.List;
/**
-
功能:按班级查询学生记录
-
作者:周许苛
-
日期:2019年6月20日
/
public class FindStudentsByClassFrame extends JFrame {
/*- 班级标签
/
private JLabel lblInputClass;
/* - 班级文本框
/
private JTextField txtClass;
/* - 面板
/
private JPanel panel;
private JPanel pnlSouth;
private JPanel pnlCenter;
private JPanel pnlNorth;
/* - 按钮
/
private JButton btnQuery;
private JButton btnBrowseAll;
private JButton btnPrint;
private JButton btnExit;
/* - 记录行集
/
private Vector rows;
/* - 表格列标题
/
private Vector colHead;
/* - 表格
/
private JTable table;
/* - 滚动面板
*/
private JScrollPane scroller;
/**
- 当前记录行号
/
private int currentRow;
/* - 学生列表
/
private List students;
/* - 创建学生服务对象
*/
private StudentService studentService;
/**
- 构造方法
- @param title
*/
public FindStudentsByClassFrame(String title) {
super(title);
intiGUI();
}
/**
-
初始化用户界面
*/
private void intiGUI() {
// 创建组件
panel = (JPanel) getContentPane();
pnlNorth = new JPanel();
pnlCenter = new JPanel();
pnlSouth = new JPanel();rows = new Vector();
colHead = new Vector();lblInputClass = new JLabel(“输入班级:”);
txtClass = new JTextField(10);
txtClass.setHorizontalAlignment(JTextField.CENTER);
btnQuery = new JButton(“查询[Q]”);
btnQuery.setMnemonic(KeyEvent.VK_Q);
btnBrowseAll = new JButton(“显示全部记录[A]”);
btnBrowseAll.setMnemonic(KeyEvent.VK_A);
btnPrint = new JButton(“打印[P]”);
btnPrint.setMnemonic(KeyEvent.VK_D);
btnExit = new JButton(“退出[X]”);
btnExit.setMnemonic(KeyEvent.VK_X);// 添加组件
panel.add(pnlSouth, BorderLayout.SOUTH);
panel.add(pnlCenter, BorderLayout.CENTER);
panel.add(pnlNorth, BorderLayout.NORTH);pnlNorth.add(lblInputClass);
pnlNorth.add(txtClass);
pnlNorth.add(btnQuery);
pnlNorth.add(btnBrowseAll);
pnlSouth.setLayout(new FlowLayout(FlowLayout.RIGHT));
pnlSouth.add(btnPrint);
pnlSouth.add(btnExit);
pnlCenter.setLayout(new BorderLayout());// 创建标题边框对象
TitledBorder tb = new TitledBorder(“查询结果”);
pnlCenter.setBorder(tb);// 创建学生服务对象
studentService = new StudentServiceImpl();
// 获取全部学生列表
students = studentService.findAllStudents();
// 填充表格数据
fillTableData();// 设置窗口大小
setSize(600, 350);
// 设置窗口不可调整大小
setResizable(false);
// 设置窗口屏幕居中
setLocationRelativeTo(null);
// 设置窗口标题
setTitle(“按姓名查询学生记录”);
// 设置窗口可见
setVisible(true);
// 设置窗口默认关闭操作
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);// 【退出】按钮单击事件
btnExit.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
dispose();
}
});// 【打印】按钮单击事件
btnPrint.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
try {
table.print();
} catch (PrinterException e1) {
e1.printStackTrace();
}
}
});// 【查询】按钮单击事件
btnQuery.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
doQuery();
}
});// 【显示全部记录】按钮单击事件
btnBrowseAll.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
// 获取全部学生记录
students = studentService.findAllStudents();
// 填充表格数据
fillTableData();
}
});// 【班级】文本框按键事件
txtClass.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ENTER) {
doQuery();
}
}
});// 表格单击事件
table.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
// 获取当前行的行数
int row = table.rowAtPoint(e.getPoint());
// 选中鼠标单击的行
table.setRowSelectionInterval(row, row);
// 设置文本框内容
txtClass.setText(table.getValueAt(row, 5).toString());
}
});
}
/**
- 查询方法
*/
private void doQuery() {
// 获取查询班级
String clazz = txtClass.getText().trim();
if (!clazz.equals("")) {
// 按班级查询获取学生列表
students = studentService.findStudentsByClass(clazz);
// 填充表格
fillTableData();
} else {
JOptionPane.showMessageDialog(this, “请输入待查班级!”, “警告”, JOptionPane.WARNING_MESSAGE);
txtClass.requestFocus();
}
}
/**
-
填充表格方法
*/
private void fillTableData() {
// 填充表头
colHead.clear();
colHead.add(“班级”);
colHead.add(“班级”);
colHead.add(“性别”);
colHead.add(“年龄”);
colHead.add(“系部”);
colHead.add(“班级”);
colHead.add(“电话”);// 填充表记录
rows.clear();
for (Student student : students) {
Vector currentRow = new Vector();
currentRow.addElement(student.getId());
currentRow.addElement(student.getName());
currentRow.addElement(student.getSex());
currentRow.addElement(student.getAge() + “”);
currentRow.addElement(student.getDepartment());
currentRow.addElement(student.getClazz());
currentRow.addElement(student.getTelephone());
// 将当前行添加到记录行集
rows.add(currentRow);
}// 创建表格(参数1:记录集;参数2:表头)
table = new JTable(rows, colHead);// 定义滚动面板
scroller = new JScrollPane(table, JScrollPane.VERTICAL_SCROLLBAR_AS_NEEDED,
JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
// 将滚动面板添加到中心面板
pnlCenter.add(scroller, BorderLayout.CENTER);// 重绘窗体
repaint();// 判断是否有记录行
if (rows.isEmpty()) {
JOptionPane.showMessageDialog(this, “没有符合条件的记录!”, “错误提示”, JOptionPane.WARNING_MESSAGE);
txtClass.setText("");
} else {
// 让滚动条移到最上方
scroller.getVerticalScrollBar().setValue(0);
}
}
/**
- 主方法
- @param args
*/
public static void main(String[] args) {
new FindStudentsByClassFrame("");
}
}
- 班级标签
10.运行结果如下:
七、创建一个按系部查询学生的记录的类
FindStudentsByDepartmentFrame
1.
2.先是构造方法、主方法、初始化用户界面。
3.创建组件、添加组件、创建标题边框对象、创建学生服务对象、获取全部学生列表、填充表格数据。
4.设置窗口的大小、标题以及退出按钮的单击事件。
5.打印按钮的单击事件、查询按钮的单击事件、显示全部记录按钮单击事件、文本框按键事件、系部文本框按键事件。
6.查询方法、填充表格的方法、填充记录、创建表格、定义滚动面板。
7.代码如下:
package net.zxk.student.gui;
import net.zxk.student.bean.Student;
import net.zxk.student.service.StudentService;
import net.zxk.student.service.impl.StudentServiceImpl;
import javax.swing.;
import javax.swing.border.TitledBorder;
import java.awt.;
import java.awt.event.*;
import java.awt.print.PrinterException;
import java.util.Vector;
import java.util.List;
/**
-
功能:按系部查询学生的记录
-
作者:周许苛
-
日期:2019年6月22日
/
public class FindStudentsByDepartmentFrame extends JFrame {
/*- 系部标签
/
private JLabel lblInputDepartment;
/* - 系部文本框
/
private JTextField txtDepartment;
/* - 面板
/
private JPanel panel;
private JPanel pnlSouth;
private JPanel pnlCenter;
private JPanel pnlNorth;
/* - 按钮
/
private JButton btnQuery;
private JButton btnBrowseAll;
private JButton btnPrint;
private JButton btnExit;
/* - 记录行集
/
private Vector rows;
/* - 表格列标题
/
private Vector colHead;
/* - 表格
/
private JTable table;
/* - 滚动面板
*/
private JScrollPane scroller;
/**
- 当前记录行号
/
private int currentRow;
/* - 学生列表
/
private List students;
/* - 创建学生服务对象
*/
private StudentService studentService;
/**
- 构造方法
- @param title
*/
public FindStudentsByDepartmentFrame(String title) {
super(title);
intiGUI();
}
/**
-
初始化用户界面
*/
private void intiGUI() {
// 创建组件
panel = (JPanel) getContentPane();
pnlNorth = new JPanel();
pnlCenter = new JPanel();
pnlSouth = new JPanel();rows = new Vector();
colHead = new Vector();lblInputDepartment = new JLabel(“输入系部:”);
txtDepartment = new JTextField(10);
txtDepartment.setHorizontalAlignment(JTextField.CENTER);
btnQuery = new JButton(“查询[Q]”);
btnQuery.setMnemonic(KeyEvent.VK_Q);
btnBrowseAll = new JButton(“显示全部记录[A]”);
btnBrowseAll.setMnemonic(KeyEvent.VK_A);
btnPrint = new JButton(“打印[P]”);
btnPrint.setMnemonic(KeyEvent.VK_D);
btnExit = new JButton(“退出[X]”);
btnExit.setMnemonic(KeyEvent.VK_X);// 添加组件
panel.add(pnlSouth, BorderLayout.SOUTH);
panel.add(pnlCenter, BorderLayout.CENTER);
panel.add(pnlNorth, BorderLayout.NORTH);pnlNorth.add(lblInputDepartment);
pnlNorth.add(txtDepartment);
pnlNorth.add(btnQuery);
pnlNorth.add(btnBrowseAll);
pnlSouth.setLayout(new FlowLayout(FlowLayout.RIGHT));
pnlSouth.add(btnPrint);
pnlSouth.add(btnExit);
pnlCenter.setLayout(new BorderLayout());// 创建标题边框对象
TitledBorder tb = new TitledBorder(“查询结果”);
pnlCenter.setBorder(tb);// 创建学生服务对象
studentService = new StudentServiceImpl();
// 获取全部学生列表
students = studentService.findAllStudents();
// 填充表格数据
fillTableData();// 设置窗口大小
setSize(600, 350);
// 设置窗口不可调整大小
setResizable(false);
// 设置窗口屏幕居中
setLocationRelativeTo(null);
// 设置窗口标题
setTitle(“按系部查询学生记录”);
// 设置窗口可见
setVisible(true);
// 设置窗口默认关闭操作
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);// 【退出】按钮单击事件
btnExit.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
dispose();
}
});// 【打印】按钮单击事件
btnPrint.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
try {
table.print();
} catch (PrinterException e1) {
e1.printStackTrace();
}
}
});// 【查询】按钮单击事件
btnQuery.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
doQuery();
}
});// 【显示全部记录】按钮单击事件
btnBrowseAll.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent event) {
// 获取全部学生记录
students = studentService.findAllStudents();
// 填充表格数据
fillTableData();
}
});// 【系部】文本框按键事件
txtDepartment.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ENTER) {
doQuery();
}
}
});// 表格单击事件
table.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
// 获取当前行的行数
int row = table.rowAtPoint(e.getPoint());
// 选中鼠标单击的行
table.setRowSelectionInterval(row, row);
// 设置文本框内容
txtDepartment.setText(table.getValueAt(row, 5).toString());
}
});
}
/**
- 查询方法
*/
private void doQuery() {
// 获取查询系部
String department = txtDepartment.getText().trim();
if (!department.equals("")) {
// 按系部查询获取学生列表
students = studentService.findStudentsByDepartment(department);
// 填充表格
fillTableData();
} else {
JOptionPane.showMessageDialog(this, “请输入待查系部!”, “警告”, JOptionPane.WARNING_MESSAGE);
txtDepartment.requestFocus();
}
}
/**
-
填充表格方法
*/
private void fillTableData() {
// 填充表头
colHead.clear();
colHead.add(“系部”);
colHead.add(“系部”);
colHead.add(“性别”);
colHead.add(“年龄”);
colHead.add(“系部”);
colHead.add(“系部”);
colHead.add(“电话”);// 填充表记录
rows.clear();
for (Student student : students) {
Vector currentRow = new Vector();
currentRow.addElement(student.getId());
currentRow.addElement(student.getName());
currentRow.addElement(student.getSex());
currentRow.addElement(student.getAge() + “”);
currentRow.addElement(student.getDepartment());
currentRow.addElement(student.getClazz());
currentRow.addElement(student.getTelephone());
// 将当前行添加到记录行集
rows.add(currentRow);
}// 创建表格(参数1:记录集;参数2:表头)
table = new JTable(rows, colHead);// 定义滚动面板
scroller = new JScrollPane(table, JScrollPane.VERTICAL_SCROLLBAR_AS_NEEDED,
JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
// 将滚动面板添加到中心面板
pnlCenter.add(scroller, BorderLayout.CENTER);// 重绘窗体
repaint();// 判断是否有记录行
if (rows.isEmpty()) {
JOptionPane.showMessageDialog(this, “没有符合条件的记录!”, “错误提示”, JOptionPane.WARNING_MESSAGE);
txtDepartment.setText("");
} else {
// 让滚动条移到最上方
scroller.getVerticalScrollBar().setValue(0);
}
}
/**
- 主方法
- @param args
*/
public static void main(String[] args) {
new FindStudentsByDepartmentFrame("");
}
- 系部标签
}
8、运行结果如下:
上一篇: 经典算法 - 最短路径问题与Dijkstra、Floyd算法
下一篇: 简单排序之冒泡排序