JAVA实训项目之学生管理系统(JDBC+GUI)
时间:2022-08-06 09:30:00
本系统采用设计Java作为设计语言,MySQL简单来说,整个系统都涉及到数据库Swing界面的开发,以及数据库的一些操作、查询、添加、删除等,通过上述操作完成学生管理系统的基本功能。
由于时间和精力(这个项目完全由博主完成)一人独立完成),巨丑的外表,但是功能已经实现了。因为篇幅太长,总共有25个类别,大概有2600-2700行代码,博主分两篇文章写,写的是教师功能。
这是博主大一期末实训项目,相当简陋不喜欢就不要喷。另外,可以借鉴功能实现的过程和思路,但是不建议抄袭哦(由于演示时间过长,本文不像学生功能那样放置演示过程)
本文应用的主要技术如下:
GUI:java实现窗体、Swing。其实JAVA Swing的GUI目前,企业不再使用,主要是一些学校和培训机构教学生写一些游戏,小项目,练习手
JDBC的全称是JAVA数据库连接(Java Database Connectivity)。一套用于执行SQL语句的Java API。通过这套应用程序API连接到关系数据库并使用它SQL完成数据库中数据的新增、删除、修改和查询。
实现的功能有:
用户登录功能:
1.可以选择学生或教师登录
学生功能:
1、修改密码
2、查询成绩
3.查询学籍信息
查看课程信息
5、退出系统
教师功能:
1、添加用户
2、删除用户
3、修改密码
4、退出系统
5.添加绩效信息
6.删除绩效信息
7.修改绩效信息
8.查询结果信息
9.添加学籍信息
10.删除学籍信息
修改学籍信息
12.查询学籍信息
13.添加课程信息
删除课程信息
修改课程信息
查询课程信息
目录
教师主页:
系统管理:
添加用户功能:
删除用户功能:
成绩管理:
添加性能功能:
修改成绩功能:
查询成绩功能:
删除成绩功能:
学籍管理:
增加学籍功能:
修改学籍功能:
查询学籍功能:
删除学籍功能:
课程管理:
增加课程功能:
修改课程功能:
查询课程功能:
删除课程功能
数据库表和数据:
实现教师功能代码:
登录页面:
用GUI通过写窗体及相关内容,通过JDBC连接数据库。然后通过获得的学生身份或教师身份,通过数据库对应的表中是否有该账户,完成登录,并将其转移到相应身份的所有功能页面。
import javax.swing.*; import java.awt.*; import java.awt.event.*; import java.sql.*; public class 登录功能 { public static void main(String[] args) { new dl(); } } class dl { public static String xh;///定义参数记录登录的帐户 public void dl(){ } public static String getXh() { return xh; } public static void setXh(String xh) { dl.xh = xh; } JFrame jf; JLabel l1,l2,l3; JTextField f1; JPasswordField f2;
JButton jb1,jb2;
JCheckBox jc;
String data;//存储学生或教师身份的选择
public dl() {
jf = new JFrame("系统登录窗口");
jf.setSize(320,400);
jf.setLocationRelativeTo(null);//设置窗口每次启动都显示在屏幕正中央
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.setLayout(null);
Font font = new Font("仿宋", Font.BOLD, 20);//设置统一的字体,让代码更加整洁美观
JComboBox jcb=new JComboBox<>();
jcb.addItem("身份");
jcb.addItem("学生");
jcb.addItem("教师");
JTextField textField=new JTextField(20);
jcb.setBounds(10,55,90,25);
jcb.setFont(font);
//为JComboBox下拉框组件注册动作监听器
jcb.addActionListener(e -> {
data=(String)jcb.getSelectedItem();
});
l3 = new JLabel("欢迎来到学生管理系统");
l3.setBounds(55,10,500,40);
l3.setFont(font);
l1 = new JLabel("账 号:");
l1.setBounds(10,100,100,40);
l1.setFont(font);
f1 = new JTextField(null,20);
f1.setBounds(90,107,180,30);
f1.setFont(font);
l2 = new JLabel("密 码:");
l2.setBounds(8,145,100,40);
l2.setFont(font);
f2=new JPasswordField(null,20);
f2.setBounds(90,150,180,30);
f2.setEchoChar('*');//设置密码的外显为*
f2.setFont(font);
jc=new JCheckBox("显示密码");
jc.setBounds(230,250,80,40);
jc.addItemListener(new ItemListener() {
public void itemStateChanged(ItemEvent e) {
if (e.getStateChange() == ItemEvent.SELECTED) {//被选中
f2.setEchoChar((char) 0);
} else {
f2.setEchoChar('*');
}
}
});
ActionListener listener=new AbstractAction() {
@Override
public void actionPerformed(ActionEvent e) {
}
};
jc.addActionListener(listener);
jb1 = new JButton("登录");
jb1.setBounds(30,200,80,40);
//匿名内部类
jb1.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
Statement st=null;
Connection con=null;
ResultSet rs=null;
try {
//注册驱动
Class.forName("com.mysql.cj.jdbc.Driver");
//这里的3306/后跟的是数据库名
//获取数据库连接
String url="jdbc:mysql://localhost:3306/students?serverTimezone=GMT%2B8";
//通过DriverManager完成注册
con= DriverManager.getConnection(url,"root","123");
//执行SQL语句
String sql="select * from dl";//from 后跟表名
st=con.createStatement();
rs=st.executeQuery(sql);
boolean flag=false;
while(rs.next()){
//如果输入的用户名和密码与数据库中的用户和对应的密码相同,则弹出“登录成功!”的窗口
if(f1.getText().equals(rs.getString(1))&&f2.getText().equals(rs.getString(2))
&&data.equals("学生")){//学生账户登录,转到学生能够拥有的功能的页面上
JOptionPane.showMessageDialog(null, "登录成功!");
dl.setXh(f1.getText());
new student();
flag=true;//登陆成功后将标记改为true方便确认
jf.dispose();//关闭窗体,释放所有资源
break;
}
if(f1.getText().equals(rs.getString(1))&&f2.getText().equals(rs.getString(2))
&&data.equals("教师")){//教师账户登录,转到教师能够拥有的功能的页面上
JOptionPane.showMessageDialog(null, "登录成功!");
xh=f1.getText();
new teacher();
flag=true;//登陆成功后将标记改为true方便确认
jf.dispose();//关闭窗体,释放所有资源
break;
}
}
if(flag==false){//如果标记为false,则表示用户名和密码在数据库中未找到,弹出“登录失败!请重新输入!”的窗口
JOptionPane.showMessageDialog(null, "登录失败!请重新输入!");
f1.setText(null);//清空账号栏
f2.setText(null);//清空密码栏
}
} catch (ClassNotFoundException ex) {
ex.printStackTrace();
} catch (SQLException ex) {
ex.printStackTrace();
}
}
});
jb1.setFont(font);
jb2 = new JButton("退出");
jb2.setBounds(150,200,80,40);
//匿名内部类
jb2.addMouseListener(new MouseAdapter() {
//重写鼠标点击事件
public void mouseClicked(MouseEvent e) {//如果点击了退出按钮,则弹出“退出成功!”的窗口
JOptionPane.showMessageDialog(null, "退出成功!");
//系统退出
System.exit(0);
}
});
jb2.setFont(font);
//将这些按钮和文本等加入到窗体中
jf.add(l1);
jf.add(f1);
jf.add(l2);
jf.add(f2);
jf.add(l3);
jf.add(jb1);
jf.add(jb2);
jf.add(jc);
jf.add(jcb);
jf.setVisible(true);//让组件显示
}
}
教师主页面:
import javax.swing.*;
import java.awt.*;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
public class 教师页面 {
public static void main(String[] args) {
new teacher();
}
}
class teacher{
JFrame jf;
JLabel l1;
JButton jb1, jb2,jb3,jb4,jb5,jb6;
public teacher() {
jf = new JFrame("教师管理系统");
jf.setSize(260, 400);//设置窗体大小
jf.setLocationRelativeTo(null);//设置窗口每次启动都显示在屏幕正中央
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.setLayout(null);
Font font = new Font("仿宋", Font.BOLD, 20);//设置统一的字体,让代码更加整洁美观
l1 = new JLabel("请选择你需要进行的操作");
l1.setBounds(10,10,500,40);
l1.setFont(font);
jb1 = new JButton("系统管理");
jb1.setBounds(45, 50, 150, 30);
jb1.setFont(font);
//匿名内部类
jb1.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
//跳转到教师的系统管理页面
new txt();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb2=new JButton("成绩管理");
jb2.setBounds(45,100,150,30);
jb2.setFont(font);
jb2.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//跳转到教师的成绩管理页面
new tcj();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb3=new JButton("学籍管理");
jb3.setBounds(45,150,150,30);
jb3.setFont(font);
jb3.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//跳转到教师的学籍管理页面
new txj();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb4=new JButton("课程管理");
jb4.setBounds(45,200,150,30);
jb4.setFont(font);
jb4.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//跳转到教师课程管理页面
new tkc();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb5=new JButton("返回");
jb5.setBounds(17,250,80,30);
jb5.setFont(font);
jb5.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//返回登录界面
new dl();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb6 = new JButton("退出");
jb6.setBounds(150, 250, 80, 30);
//匿名内部类
jb6.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
JOptionPane.showMessageDialog(null, "退出成功!");
//系统退出
System.exit(0);
}
});
jb6.setFont(font);
//将这些按钮和文本等加入到窗体中
jf.add(l1);
jf.add(jb1);
jf.add(jb2);
jf.add(jb3);
jf.add(jb4);
jf.add(jb5);
jf.add(jb6);
jf.setVisible(true);//让组件显示
}
}
系统管理:
import javax.swing.*;
import java.awt.*;
import java.awt.event.ItemEvent;
import java.awt.event.ItemListener;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
public class 教师系统管理 {
public static void main(String[] args) {
new txt();
}
}
class txt{
JFrame jf;
JLabel l1,l2,l3;
JTextField f1;
JPasswordField f2,f3;
JButton jb1,jb2,jb3,jb4,jb5;
JCheckBox jc;
public txt() {
jf = new JFrame("系统管理");
jf.setSize(320,300);//设置窗体大小
jf.setLocationRelativeTo(null);//设置窗口每次启动都显示在屏幕正中央
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.setLayout(null);
Font font = new Font("仿宋", Font.BOLD, 20);//设置统一的字体,让代码更加整洁美观
l1 = new JLabel("学号:");
l1.setBounds(10,10,100,40);
l1.setFont(font);
f1 = new JTextField(null,20);
f1.setBounds(90,15,180,30);
f1.setFont(font);
l2 = new JLabel("新密码:");
l2.setBounds(8, 50, 100, 40);
l2.setFont(font);
f2 = new JPasswordField(null, 20);
f2.setBounds(90, 55, 180, 30);
f2.setEchoChar('*');//设置密码的外显为*
f2.setFont(font);
l3 = new JLabel("确认密码:");
l3.setBounds(8, 88, 130, 40);
l3.setFont(font);
f3 = new JPasswordField(null, 20);
f3.setBounds(120, 95, 160, 30);
f3.setEchoChar('*');//设置密码的外显为*
jc=new JCheckBox("显示密码");//创建一个复选按钮
jc.setBounds(230,210,80,40);
jc.addItemListener(new ItemListener() {
public void itemStateChanged(ItemEvent e) {
if (e.getStateChange() == ItemEvent.SELECTED) {//被选中
f2.setEchoChar((char) 0);//显示原本的数据
f3.setEchoChar((char)0);//显示原本的数据
} else {
f2.setEchoChar('*');//设置密码的外显为*
f3.setEchoChar('*');//设置密码的外显为*
}
}
});
f3.setFont(font);
jb1 = new JButton("修改密码");
jb1.setBounds(15, 130, 120, 30);
//匿名内部类
jb1.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
PreparedStatement ps = null;//PreparedStatement==>表示预编译的SQL语句的对象。
// SQL语句已预编译并存储在PreparedStatement对象中。
Connection con = null;//Connection==>与特定数据库的连接
try {
//注册驱动
Class.forName("com.mysql.cj.jdbc.Driver");
//这里的3306/后跟的是数据库名
//获取数据库连接
String url = "jdbc:mysql://localhost:3306/students?serverTimezone=GMT%2B8";
//通过DriverManager完成注册
con = DriverManager.getConnection(url, "root", "123");
//执行SQL语句
String sql = "update dl set password=? where studentnumber=?";
ps = con.prepareStatement(sql);
if(f1.getText().length()!=0) {
ps.setString(2, f1.getText());
}else{
JOptionPane.showMessageDialog(null, "学号不能为空!");//弹出窗口
}
if(f2.getText().length()!=0){
//注:这里的所有getText()都不能写成!=null
ps.setString(1, f2.getText());
}else{
JOptionPane.showMessageDialog(null, "新密码不能为空!");//弹出窗口
}
} catch (ClassNotFoundException ex) {
ex.printStackTrace();
} catch (SQLException ex) {
ex.printStackTrace();
}
if (new String(f2.getPassword()).equals(new String(f3.getPassword()))) {//如果新密码与确认密码一致
if (new String(f2.getPassword()).equals(new String(f3.getPassword()))&&
f1.getText().length()!=0&&f2.getText().length()!=0) {//如果新密码与确认密码一致,学号和密码不为空,则修改成功
JOptionPane.showMessageDialog(null, "修改成功!");
//修改成功后跳转回教师页面
new teacher();
jf.dispose();//关闭窗体,释放所有资源
try {
int i = ps.executeUpdate();//将注册的账户存储到数据库中
} catch (SQLException ex) {
ex.printStackTrace();
}
}
} else {
JOptionPane.showMessageDialog(null, "修改失败!新密码与确认密码不一致!");
f2.setText(null);//清空新密码
f3.setText(null);//清空确认密码
}
}
});
jb1.setFont(font);
jb2 = new JButton("退出");
jb2.setBounds(180, 170, 80, 40);
//匿名内部类
jb2.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
JOptionPane.showMessageDialog(null, "退出成功!");
//系统退出
System.exit(0);
}
});
jb3=new JButton("返回");
jb3.setBounds(30,170,80,40);
jb3.setFont(font);
jb3.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//返回教师主页面
new teacher();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb2.setFont(font);
jb4=new JButton("添加用户");
jb4.setBounds(165, 130, 120, 30);
jb4.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//转到注册功能页面
new zc();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb4.setFont(font);
jb5 = new JButton("删除用户");
jb5.setBounds(85, 220, 120, 30);
jb5.setFont(font);
jb5.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//转到删除用户页面
new scyh();
jf.dispose();//关闭窗体,释放所有资源
}
});
//将这些按钮和文本等加入到窗体中
jf.add(l1);
jf.add(f1);
jf.add(l2);
jf.add(f2);
jf.add(l3);
jf.add(f3);
jf.add(jc);
jf.add(jb1);
jf.add(jb2);
jf.add(jb3);
jf.add(jb4);
jf.add(jb5);
jf.setVisible(true);//让组件显示
}
}
添加用户功能:
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
import java.sql.*;
public class 注册功能 {
public static void main(String[] args) {
new zc();
}
}
class zc{
JFrame jf;
JLabel l1,l2,l3;
JTextField f1;
JPasswordField f2,f3;
JButton jb1,jb2,jb3;
JCheckBox jc;
public zc() {
jf = new JFrame("系统注册窗口");
jf.setSize(320,300);//设置窗体大小
jf.setLocationRelativeTo(null);//设置窗口每次启动都显示在屏幕正中央
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.setLayout(null);
Font font = new Font("仿宋", Font.BOLD, 20);//设置统一的字体,让代码更加整洁美观
l1 = new JLabel("学号:");
l1.setBounds(10,10,100,40);
l1.setFont(font);
f1 = new JTextField(null,20);
f1.setBounds(90,15,180,30);
f1.setFont(font);
l2 = new JLabel("密 码:");
l2.setBounds(8, 50, 100, 40);
l2.setFont(font);
f2 = new JPasswordField(null, 20);
f2.setBounds(90, 55, 180, 30);
f2.setEchoChar('*');//设置密码的外显为*
f2.setFont(font);
l3 = new JLabel("确认密码:");
l3.setBounds(8, 88, 130, 40);
l3.setFont(font);
f3 = new JPasswordField(null, 20);
f3.setBounds(120, 95, 160, 30);
f3.setEchoChar('*');//设置密码的外显为*
jc=new JCheckBox("显示密码");//创建一个复选按钮
jc.setBounds(230,140,80,40);
jc.addItemListener(new ItemListener() {
public void itemStateChanged(ItemEvent e) {
if (e.getStateChange() == ItemEvent.SELECTED) {//被选中
f2.setEchoChar((char) 0);//显示原本的数据
f3.setEchoChar((char)0);//显示原本的数据
} else {
f2.setEchoChar('*');//设置密码的外显为*
f3.setEchoChar('*');//设置密码的外显为*
}
}
});
f3.setFont(font);
jb1 = new JButton("注册");
jb1.setBounds(100, 140, 80, 40);
//匿名内部类
jb1.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
PreparedStatement ps = null;//PreparedStatement==>表示预编译的SQL语句的对象。
// SQL语句已预编译并存储在PreparedStatement对象中。
Connection con = null;//Connection==>与特定数据库的连接
try {
//注册驱动
Class.forName("com.mysql.cj.jdbc.Driver");
//这里的3306/后跟的是数据库名
//获取数据库连接
String url = "jdbc:mysql://localhost:3306/students?serverTimezone=GMT%2B8";
//通过DriverManager完成注册
con = DriverManager.getConnection(url, "root", "123");
//执行SQL语句
String sql = "insert into dl(studentnumber,password) values(?,?)";
ps = con.prepareStatement(sql);
if(f1.getText().length()!=0){
//注:这里的所有getText()都不能写成!=null
ps.setString(1, f1.getText());
}else{
JOptionPane.showMessageDialog(null, "学号不能为空!");//弹出窗口
}
if(f2.getText().length()!=0) {
ps.setString(2, f2.getText());
}else{
JOptionPane.showMessageDialog(null, "密码不能为空!");
}
} catch (ClassNotFoundException ex) {
ex.printStackTrace();
} catch (SQLException ex) {
ex.printStackTrace();
}
if (new String(f2.getPassword()).equals(new String(f3.getPassword()))) {//如果密码与确认密码一致
if (new String(f2.getPassword()).equals(new String(f3.getPassword()))&&
f1.getText().length()!=0&&f2.getText().length()!=0) {//如果密码与确认密码一致,学号和密码不为空,则注册成功
JOptionPane.showMessageDialog(null, "注册成功!");
f1.setText(null);
f2.setText(null);
f3.setText(null);
try {
int i = ps.executeUpdate();//将注册的账户存储到数据库中
} catch (SQLException ex) {
ex.printStackTrace();
}
}
} else {
JOptionPane.showMessageDialog(null, "注册失败!密码与确认密码不一致!");
f2.setText(null);//清空密码
f3.setText(null);//清空确认密码
}
}
});
jb1.setFont(font);
jb2 = new JButton("退出");
jb2.setBounds(180, 200, 80, 40);
//匿名内部类
jb2.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
JOptionPane.showMessageDialog(null, "退出成功!");
//系统退出
System.exit(0);
}
});
jb2.setFont(font);
jb3=new JButton("返回");
jb3.setBounds(40,200,80,40);
jb3.setFont(font);
jb3.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//跳转到教师的系统管理页面
new txt();
jf.dispose();//关闭窗体,释放所有资源
}
});
//将这些按钮和文本等加入到窗体中
jf.add(l1);
jf.add(f1);
jf.add(l2);
jf.add(f2);
jf.add(l3);
jf.add(f3);
jf.add(jc);
jf.add(jb1);
jf.add(jb2);
jf.add(jb3);
jf.setVisible(true);//让组件显示
}
}
删除用户功能:
import javax.swing.*;
import java.awt.*;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
public class 删除用户功能 {
public static void main(String[] args) {
new scyh();
}
}
class scyh{
JFrame jf;
JLabel l1;
JTextField f1;
JButton jb1,jb2,jb3;
public scyh(){
jf = new JFrame("删除用户");
jf.setSize(320,280);//设置窗体大小
jf.setLocationRelativeTo(null);//设置窗口每次启动都显示在屏幕正中央
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.setLayout(null);
Font font = new Font("仿宋", Font.BOLD, 20);//设置统一的字体,让代码更加整洁美观
l1 = new JLabel("学 号:");
l1.setBounds(10,10,100,40);
l1.setFont(font);
f1 = new JTextField(null,20);
f1.setBounds(90,15,180,30);
f1.setFont(font);
jb1 = new JButton("删除用户");
jb1.setBounds(75, 75, 140, 40);
jb1.setFont(font);
jb1.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
PreparedStatement ps = null;//PreparedStatement==>表示预编译的SQL语句的对象。
// SQL语句已预编译并存储在PreparedStatement对象中。
Connection con = null;//Connection==>与特定数据库的连接
try {
//注册驱动
Class.forName("com.mysql.cj.jdbc.Driver");
//这里的3306/后跟的是数据库名
//获取数据库连接
String url = "jdbc:mysql://localhost:3306/students?serverTimezone=GMT%2B8";
//通过DriverManager完成注册
con = DriverManager.getConnection(url, "root", "123");
//执行SQL语句
String sql = "delete from dl where studentnumber=?";
ps = con.prepareStatement(sql);
if(f1.getText().length()!=0){
ps.setString(1,f1.getText());
}else{
JOptionPane.showMessageDialog(null, "学号不能为空!");
}
if(f1.getText().length()!=0){
JOptionPane.showMessageDialog(null, "删除成功!");
f1.setText(null);
int i = ps.executeUpdate();
}else{
JOptionPane.showMessageDialog(null, "删除失败!");
}
} catch (ClassNotFoundException ex) {
ex.printStackTrace();
} catch (SQLException ex) {
ex.printStackTrace();
}
}
});
jb2 = new JButton("返回");
jb2.setBounds(35, 140, 80, 40);
jb2.setFont(font);
jb2.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//返回到教师系统管理页面
new txt();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb3 = new JButton("退出");
jb3.setBounds(190, 140, 80, 40);
jb3.setFont(font);
jb3.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
JOptionPane.showMessageDialog(null, "退出成功!");
//系统退出
System.exit(0);
}
});
//将这些按钮和文本等加入到窗体中
jf.add(l1);
jf.add(f1);
jf.add(jb1);
jf.add(jb2);
jf.add(jb3);
jf.setVisible(true);//让组件显示
}
}
成绩管理:
import javax.swing.*;
import java.awt.*;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
public class 教师成绩管理 {
public static void main(String[] args) {
new tcj();
}
}
class tcj{
JFrame jf;
JButton jb1,jb2,jb3,jb4,jb5,jb6;
public tcj(){
jf = new JFrame("成绩管理");
jf.setSize(320,350);//设置窗体大小
jf.setLocationRelativeTo(null);//设置窗口每次启动都显示在屏幕正中央
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.setLayout(null);
Font font = new Font("仿宋", Font.BOLD, 20);//设置统一的字体,让代码更加整洁美观
jb1 = new JButton("添加成绩信息");
jb1.setBounds(55, 20, 200, 40);
jb1.setFont(font);
jb1.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//跳转到教师添加成绩页面
new ttjcj();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb2 = new JButton("修改成绩信息");
jb2.setBounds(55, 75, 200, 40);
jb2.setFont(font);
jb2.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//跳转到教师修改成绩页面
new txgcj();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb3 = new JButton("查询成绩信息");
jb3.setBounds(55, 125, 200, 40);
jb3.setFont(font);
jb3.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//跳转到教师查询成绩功能页面
new tcx();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb6=new JButton("删除成绩信息");
jb6.setBounds(55,175,200,40);
jb6.setFont(font);
jb6.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//跳转到教师删除成绩功能页面
new sccj();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb4 = new JButton("返回");
jb4.setBounds(30, 245, 80, 40);
jb4.setFont(font);
jb4.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//返回教师主页面
new teacher();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb5 = new JButton("退出");
jb5.setBounds(200, 245, 80, 40);
jb5.setFont(font);
jb5.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
JOptionPane.showMessageDialog(null, "退出成功!");
//系统退出
System.exit(0);
}
});
//将这些按钮和文本等加入到窗体中
jf.add(jb1);
jf.add(jb2);
jf.add(jb3);
jf.add(jb4);
jf.add(jb5);
jf.add(jb6);
jf.setVisible(true);//让组件显示
}
}
添加成绩功能:
import javax.swing.*;
import java.awt.*;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
public class 添加成绩功能 {
public static void main(String[] args) {
new ttjcj();
}
}
class ttjcj{
JFrame jf;
JLabel l1,l2,l3;
JTextField f1,f2,f3;
JButton jb1,jb2,jb3;
public ttjcj(){
jf = new JFrame("添加成绩");
jf.setSize(320,300);//设置窗体大小
jf.setLocationRelativeTo(null);//设置窗口每次启动都显示在屏幕正中央
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.setLayout(null);
Font font = new Font("仿宋", Font.BOLD, 20);//设置统一的字体,让代码更加整洁美观
l1 = new JLabel("学 号:");
l1.setBounds(10,10,100,40);
l1.setFont(font);
f1 = new JTextField(null,20);
f1.setBounds(90,15,180,30);
f1.setFont(font);
l2 = new JLabel("课程名:");
l2.setBounds(8, 50, 100, 40);
l2.setFont(font);
f2=new JTextField(null,20);
f2.setBounds(90,55,180,30);
f2.setFont(font);
l3 = new JLabel("成 绩:");
l3.setBounds(8, 90, 100, 40);
l3.setFont(font);
f3=new JTextField(null,20);
f3.setBounds(90,95,180,30);
f3.setFont(font);
jb1 = new JButton("添加成绩信息");
jb1.setBounds(65, 140, 180, 40);
jb1.setFont(font);
jb1.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
PreparedStatement ps = null;//PreparedStatement==>表示预编译的SQL语句的对象。
// SQL语句已预编译并存储在PreparedStatement对象中。
Connection con = null;//Connection==>与特定数据库的连接
try {
//注册驱动
Class.forName("com.mysql.cj.jdbc.Driver");
//这里的3306/后跟的是数据库名
//获取数据库连接
String url = "jdbc:mysql://localhost:3306/students?serverTimezone=GMT%2B8";
//通过DriverManager完成注册
con = DriverManager.getConnection(url, "root", "123");
//执行SQL语句
String sql = "insert into chengji(studentnumber,course,cj) values(?,?,?)";
ps = con.prepareStatement(sql);
if (f1.getText().length() != 0) {
ps.setString(1, f1.getText());
} else {
JOptionPane.showMessageDialog(null, "学号不能为空!");//弹出窗口
}
if (f2.getText().length() != 0) {
ps.setString(2, f2.getText());
} else {
JOptionPane.showMessageDialog(null, "课程名不能为空!");//弹出窗口
}
if (f3.getText().length() != 0) {
ps.setString(3, f3.getText());
} else {
JOptionPane.showMessageDialog(null, "成绩不能为空!");//弹出窗口
}
} catch (ClassNotFoundException ex) {
ex.printStackTrace();
} catch (SQLException ex) {
ex.printStackTrace();
}
if (f1.getText().length() != 0 && f2.getText().length() != 0 && f3.getText().length() != 0) {//如果学号、课程名、成绩信息都填写了,便添加成功
JOptionPane.showMessageDialog(null, "添加成功!");
f1.setText(null);
f2.setText(null);
f3.setText(null);
try {
int i = ps.executeUpdate();//将数据存储到数据库中
} catch (SQLException ex) {
ex.printStackTrace();
}
}
}
});
jb2 = new JButton("返回");
jb2.setBounds(35, 200, 80, 40);
jb2.setFont(font);
jb2.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//返回到教师成绩管理页面
new tcj();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb3 = new JButton("退出");
jb3.setBounds(190, 200, 80, 40);
jb3.setFont(font);
jb3.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
JOptionPane.showMessageDialog(null, "退出成功!");
//系统退出
System.exit(0);
}
});
//将这些按钮和文本等加入到窗体中
jf.add(l1);
jf.add(f1);
jf.add(l2);
jf.add(f2);
jf.add(l3);
jf.add(f3);
jf.add(jb1);
jf.add(jb2);
jf.add(jb3);
jf.setVisible(true);//让组件显示
}
}
修改成绩功能:
import javax.swing.*;
import java.awt.*;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.sql.*;
public class 修改成绩功能 {
public static void main(String[] args) {
new txgcj();
}
}
class txgcj{
JFrame jf;
JLabel l1,l2,l3;
JTextField f1,f2,f3;
JButton jb1,jb2,jb3;
public txgcj(){
jf = new JFrame("修改成绩");
jf.setSize(320,280);//设置窗体大小
jf.setLocationRelativeTo(null);//设置窗口每次启动都显示在屏幕正中央
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.setLayout(null);
Font font = new Font("仿宋", Font.BOLD, 20);//设置统一的字体,让代码更加整洁美观
l1 = new JLabel("学 号:");
l1.setBounds(10,10,100,40);
l1.setFont(font);
f1 = new JTextField(null,20);
f1.setBounds(90,15,180,30);
f1.setFont(font);
l2 = new JLabel("课程名:");
l2.setBounds(8, 50, 100, 40);
l2.setFont(font);
f2=new JTextField(null,20);
f2.setBounds(90,55,180,30);
f2.setFont(font);
l3=new JLabel("成 绩:");
l3.setBounds(10,90,100,40);
l3.setFont(font);
f3=new JTextField(null,20);
f3.setBounds(90,95,180,30);
f3.setFont(font);
jb1 = new JButton("修改成绩信息");
jb1.setBounds(65, 140, 180, 40);
jb1.setFont(font);
jb1.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
PreparedStatement ps = null;//PreparedStatement==>表示预编译的SQL语句的对象。
// SQL语句已预编译并存储在PreparedStatement对象中。
Connection con = null;//Connection==>与特定数据库的连接
Statement st=null;
ResultSet rs=null;
try {
//注册驱动
Class.forName("com.mysql.cj.jdbc.Driver");
//这里的3306/后跟的是数据库名
//获取数据库连接
String url = "jdbc:mysql://localhost:3306/students?serverTimezone=GMT%2B8";
//通过DriverManager完成注册
con = DriverManager.getConnection(url, "root", "123");
//执行SQL语句
String sql2="update chengji set cj=? where studentnumber=? and course=?";
ps = con.prepareStatement(sql2);
String sql = "select * from chengji";
st=con.createStatement();
rs=st.executeQuery(sql);
int flag=0;
while (rs.next()){
//根据学号和课程名修改成绩
if(rs.getString("studentnumber").equals(f1.getText())&&rs.getString("course").equals(f2.getText())){
ps.setString(1,f3.getText());
ps.setString(2,f1.getText());
ps.setString(3,f2.getText());
flag++;
}
}
if(flag==0){
JOptionPane.showMessageDialog(null, "没有该学生和课程!");
}
if(f1.getText().length()!=0&&f2.getText().length()!=0&&f3.getText().length()!=0 && flag!=0){
//如果学号、课程名、成绩都填写了,则修改成功
JOptionPane.showMessageDialog(null, "修改成功!");
f1.setText(null);
f2.setText(null);
f3.setText(null);
try {
int i = ps.executeUpdate();//将数据存储到数据库中
} catch (SQLException ex) {
ex.printStackTrace();
}
}else{
JOptionPane.showMessageDialog(null, "修改失败!");
}
} catch (ClassNotFoundException ex) {
ex.printStackTrace();
} catch (SQLException ex) {
ex.printStackTrace();
}
}
});
jb2 = new JButton("返回");
jb2.setBounds(35, 190, 80, 40);
jb2.setFont(font);
jb2.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//返回到教师成绩管理页面
new tcj();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb3 = new JButton("退出");
jb3.setBounds(190, 190, 80, 40);
jb3.setFont(font);
jb3.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
JOptionPane.showMessageDialog(null, "退出成功!");
//系统退出
System.exit(0);
}
});
//将这些按钮和文本等加入到窗体中
jf.add(l1);
jf.add(f1);
jf.add(l2);
jf.add(f2);
jf.add(l3);
jf.add(f3);
jf.add(jb1);
jf.add(jb2);
jf.add(jb3);
jf.setVisible(true);//让组件显示
}
}
查询成绩功能:
import javax.swing.*;
import java.awt.*;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.sql.*;
public class 教师查询成绩功能 {
public static void main(String[] args) {
new tcx();
}
}
class tcx{
//文本域
private JTextArea jta;
//滚动条
private JScrollPane jsp;
//面板
private JPanel jp;
//按钮
private JButton jb,jb2,jb3;
//窗体
JFrame jf;
public tcx(){
//初始化组件
jta=new JTextArea();
jf = new JFrame("查询成绩");
//将文本域添加到滚动条中,实现滚动效果
jsp=new JScrollPane(jta);
//面板
jp=new JPanel();
jb=new JButton("查询");
//将文本框和按钮添加到面板中
jb2=new JButton("返回");
jb2.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//跳转回教师成绩管理页面
new tcj();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb3=new JButton("退出");
jb3.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
JOptionPane.showMessageDialog(null, "退出成功!");
//系统退出
System.exit(0);
}
});
jp.add(jb);
jp.add(jb2);
jp.add(jb3);
//将滚动条和面板都添加到窗体中
jf.add(jsp, BorderLayout.CENTER);
jf.add(jp,BorderLayout.SOUTH);
jf.setSize(400,400);
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.setLocationRelativeTo(null);
jf.setVisible(true);//设置组件显示
//给查询按钮绑定一个监听点击事件
jb.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
Statement st=null;
Connection con=null;
ResultSet rs=null;
try {
//注册驱动
Class.forName("com.mysql.cj.jdbc.Driver");
//这里的3306/后跟的是数据库名
//获取数据库连接
String url = "jdbc:mysql://localhost:3306/students?serverTimezone=GMT%2B8";
//通过DriverManager完成注册
con = DriverManager.getConnection(url, "root", "123");
//执行SQL语句
String sql = "select * from chengji";
st=con.createStatement();
rs=st.executeQuery(sql);
String text;
while (rs.next()){
text ="学号:"+rs.getString("studentnumber")+"\n"+"课程名:"
+rs.getString("course")+"\n"+"成绩:"+rs.getString("cj")+"\n\n";
jta.append(text);
}
} catch (ClassNotFoundException ex) {
ex.printStackTrace();
} catch (SQLException ex) {
ex.printStackTrace();
}
}
});
}
}
删除成绩功能:
import javax.swing.*;
import java.awt.*;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.sql.*;
public class 删除成绩功能 {
public static void main(String[] args) {
new sccj();
}
}
class sccj{
JFrame jf;
JLabel l1,l2;
JTextField f1,f2;
JButton jb1,jb2,jb3;
public sccj(){
jf = new JFrame("删除成绩");
jf.setSize(320,280);//设置窗体大小
jf.setLocationRelativeTo(null);//设置窗口每次启动都显示在屏幕正中央
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.setLayout(null);
Font font = new Font("仿宋", Font.BOLD, 20);//设置统一的字体,让代码更加整洁美观
l1 = new JLabel("学 号:");
l1.setBounds(10,10,100,40);
l1.setFont(font);
f1 = new JTextField(null,20);
f1.setBounds(90,15,180,30);
f1.setFont(font);
l2 = new JLabel("课程名:");
l2.setBounds(8, 50, 100, 40);
l2.setFont(font);
f2=new JTextField(null,20);
f2.setBounds(90,55,180,30);
f2.setFont(font);
jb1 = new JButton("删除成绩信息");
jb1.setBounds(65, 110, 180, 40);
jb1.setFont(font);
jb1.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
PreparedStatement ps = null;//PreparedStatement==>表示预编译的SQL语句的对象。
// SQL语句已预编译并存储在PreparedStatement对象中。
Connection con = null;//Connection==>与特定数据库的连接
try {
//注册驱动
Class.forName("com.mysql.cj.jdbc.Driver");
//这里的3306/后跟的是数据库名
//获取数据库连接
String url = "jdbc:mysql://localhost:3306/students?serverTimezone=GMT%2B8";
//通过DriverManager完成注册
con = DriverManager.getConnection(url, "root", "123");
//执行SQL语句
String sql = "delete from chengji where studentnumber=? and course=?";
ps = con.prepareStatement(sql);
if(f1.getText().length()!=0){
ps.setString(1,f1.getText());
}else{
JOptionPane.showMessageDialog(null, "学号不能为空!");
}
if(f2.getText().length()!=0){
ps.setString(2,f2.getText());
}else{
JOptionPane.showMessageDialog(null, "课程名不能为空!");
}
if(f1.getText().length()!=0&&f2.getText().length()!=0){
JOptionPane.showMessageDialog(null, "删除成功!");
f1.setText(null);
f2.setText(null);
int i = ps.executeUpdate();
}else{
JOptionPane.showMessageDialog(null, "删除失败!");
}
} catch (ClassNotFoundException ex) {
ex.printStackTrace();
} catch (SQLException ex) {
ex.printStackTrace();
}
}
});
jb2 = new JButton("返回");
jb2.setBounds(35, 165, 80, 40);
jb2.setFont(font);
jb2.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//返回到教师成绩管理页面
new tcj();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb3 = new JButton("退出");
jb3.setBounds(190, 165, 80, 40);
jb3.setFont(font);
jb3.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
JOptionPane.showMessageDialog(null, "退出成功!");
//系统退出
System.exit(0);
}
});
//将这些按钮和文本等加入到窗体中
jf.add(l1);
jf.add(f1);
jf.add(l2);
jf.add(f2);
jf.add(jb1);
jf.add(jb2);
jf.add(jb3);
jf.setVisible(true);//让组件显示
}
}
学籍管理:
import javax.swing.*;
import java.awt.*;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
public class 教师学籍管理 {
public static void main(String[] args) {
new txj();
}
}
class txj{
JFrame jf;
JButton jb1,jb2,jb3,jb4,jb5,jb6;
public txj(){
jf = new JFrame("学籍管理");
jf.setSize(320,350);//设置窗体大小
jf.setLocationRelativeTo(null);//设置窗口每次启动都显示在屏幕正中央
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.setLayout(null);
Font font = new Font("仿宋", Font.BOLD, 20);//设置统一的字体,让代码更加整洁美观
jb1 = new JButton("添加学籍信息");
jb1.setBounds(55, 20, 200, 40);
jb1.setFont(font);
jb1.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//跳转到教师添加学籍页面
new ttjxj();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb2 = new JButton("修改学籍信息");
jb2.setBounds(55, 75, 200, 40);
jb2.setFont(font);
jb2.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//跳转到教师修改学籍页面
new txgxj();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb3 = new JButton("查询学籍信息");
jb3.setBounds(55, 125, 200, 40);
jb3.setFont(font);
jb3.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//跳转到教师查询功能页面
new txjcx();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb6=new JButton("删除学籍信息");
jb6.setBounds(55,175,200,40);
jb6.setFont(font);
jb6.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//跳转到教师删除学籍功能页面
new scxj();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb4 = new JButton("返回");
jb4.setBounds(30, 245, 80, 40);
jb4.setFont(font);
jb4.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
//返回教师主页面
new teacher();
jf.dispose();//关闭窗体,释放所有资源
}
});
jb5 = new JButton("退出");
jb5.setBounds(200, 245, 80, 40);
jb5.setFont(font);
jb5.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
JOptionPane.showMessageDialog(null, "退出成功!");
//系统退出
System.exit(0);
}
});
//将这些按钮和文本等加入到窗体中
jf.add(jb1);
jf.add(jb2);
jf.add(jb3);
jf.add(jb4);
jf.add(jb5);
jf.add(jb6);
jf.setVisible(true);//让组件显示
}
}
添加学籍功能:
import javax.swing.*;
import java.awt.*;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
public class 添加学籍功能 {
public static void main(String[] args) {
new ttjxj();
}
}
class ttjxj{
JFrame jf;
JLabel l1,l2,l3,l4,l5;
JTextField f1,f2,f3,f4,f5;
JButton jb1,jb2,jb3;
public ttjxj(){
jf = new JFrame("添加学籍");
jf.setSize(320,450);//设置窗体大小
jf.setLocationRelativeTo(null);//设置窗口每次启动都显示在屏幕正中央
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.setLayout(null);
Font font = new Font("仿宋", Font.BOLD, 20);//设置统一的字体,让代码更加整洁美观
l1 = new JLabel("班 级:");
l1.setBounds(10,10,100,40);
l1.setFont(font);
f1 = new JTextField(null,20);
f1.setBounds(90,15,180,30);
f1.setFont(font);
l2 = new JLabel("学 号:");
l2.setBounds(8, 50, 100, 40);
l2.setFont(font);
f2=new JTextField(null,20);
f2.setBounds(90,55,180,30);
f2.setFont(font);
l3 = new JLabel("姓 名:");
l3.setBounds(8, 90, 100, 40);
l3.setFont(font);
f3=new JTextField(null,20);
f3.setBounds(90,95,180,30);
f3.setFont(font);
l4 = new JLabel("性 别:");
l4.setBounds(8, 130, 100, 40);
l4.setFont(font);
f4=new JTextField(null,20);
f4.setBounds(90,135,180,30);
f4.setFont(font);
l5 = new JLabel("出生年月:");
l5.setBounds(8, 170, 130, 40);
l5.setFont(font);
f5=new JTextField(null,20);
f5.setBounds(90,210,180,30);
f5.setFont(font);
jb1 = new JButton("添加学籍信息");
jb1.setBounds(65, 265, 180, 40);
jb1.setFont(font);
jb1.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
PreparedStatement ps = null;//PreparedStatement==>表示预编译的SQL语句的对象。
// SQL语句已预编译并存储在PreparedStatement对象中。
Connection con = null;//Connection==>与特定数据库的连接
try {
//注册驱动
Class.forName("com.mysql.cj.jdbc.Driver");
//这里的3306/后跟的是数据库名
//获取数据库连接
String url = "jdbc:mysql://localhost:3306/students?serverTimezone=GMT%2B8";
//通过DriverManager完成注册
con = DriverManager.getConnection(url, "root", "123");
//执行SQL语句
String sql = "insert into student_status(class,studentnumber,name,sex,date) values(?,?,?,?,?)";
ps = con.prepareStatement(sql);
if (f1.getText().length() != 0) {
ps.setString(1, f1.getText());
} else {
JOptionPane.showMessageDialog(null, "班级不能为空!");//弹出窗口
}
if (f2.getText().length() != 0) {
ps.setString(2, f2.getText());
} else {
JOptionPane.showMessageDialog(null, "学号不能为空!");//弹出窗口
}
if (f3.getText().length() != 0) {
ps.setString(3, f3.getText());
} else {
JOptionPane.showMessageDialog(null, "姓名不能为空!");//弹出窗口
}
if (f4.getText().length() != 0) {
ps.setString(4, f4.getText());
} else {
JOptionPane.showMessageDialog(null, "性别不能为空!");//弹出窗口
}
if (f5.getText().length() != 0) {
ps.setS