JavaFx+MySql学生管理系统

news2025/1/16 17:07:15

前言:

        上个月学习了javafx和mysql数据库,于是写了一个学生管理系统,因为上个月在复习并且有一些事情,比较忙,所以没有更新博客了,这个项目页面虽然看着有点简陋了,但是大致内容还是比较简单的,于是现在跟大家分享一下我的学生管理系统,希望对这方面有兴趣的同学提供一些帮助

🥰个人主页:心.c

🤓文章专题:javafx+mysql管理系统

👐欢迎大家点赞👍 收藏😽

 

9a7940c627094e34946debbd787da24e.jpg

487ac90190f44b238ebafae9d457463b.png

 

目录

页面展示:

包的创建:

登录界面:

学生登录界面:

 学生信息查询:

​编辑

学生成绩查询:

管理员登录界面:

管理员学生信息管理界面:

管理员课程信息管理界面:

管理员成绩信息管理界面:

修改学生界面:

 代码展示:

主窗口(endView):

 登录界面和提示窗口(otherView):

学生:

学生界面(studentView):

学生Dao语句:

utilDao:

studentDao*:

管理员:

管理员界面(magView):

管理员工具类:

学生(studentUtil):

课程(courseUtil):

分数(scoreUtil):

判断工具类(judgeUtil):

管理员Dao类:

utilDao:

studentDao*:

courseDao:

scoreDao:

judgeDao:

domain(对象类):

student:

course:

score:

结尾


 

 

页面展示:

包的创建:

(在这里我用了一些mvc的框架结构,虽然我的代码不是很多,但是我觉得这样写可以让我们的代码变的更加简洁易懂,很有结构层次)

4033c3dc2d754754a7b3f2454d5e9845.png

登录界面:

关于登录界面(关于登录界面,写了一些关于文本输入框的判断--数据库判断是否正确和一些非空判断--)

55d6138971d64cfbb14cf719a47454e5.png

学生登录界面:

87787ba5c3924a76a98926dd8515df68.png

 学生信息查询:

8e9905fc895a44c982abbc457be7a80a.png

学生成绩查询:

97cefd35d8ad47399c72b79e965a7d4d.png

管理员登录界面:

a5114f0d903747b197c0ad925c424043.png

管理员学生信息管理界面:

49cd3ef4185041aa8d83bb07e3cc417e.png

管理员课程信息管理界面:

d7d32fcf511e4703a0701d4b44141a7f.png

管理员成绩信息管理界面:

584f66d36cdf4bb8a2c0bb845fb20d84.png

修改学生界面:

(以为这几个页面都差不多,所以在这里我就只展示一个添加学生界面了)

9f338156d1d740fca1f060ce0ede42c8.png

 

 代码展示:

 

主窗口(endView):

关于主窗口,我定义了一个静态舞台来当我的主舞台,将我的start方法中的舞台赋值给静态舞台,我设置这个舞台的目的是为了将我写的其他方法,比如登录界面等的方法里面的scene场景放到我的静态stage当中,这样我的代码在执行的时候我的页面就可以一直用主舞台了也不会显得界面很乱了,而且非常方便,简单易懂

public class endView extends Application {

    public static Stage stage;
    public static student student0;
    public static course course0;
    public static score score0;
    @Override
    public void start(Stage stage) {
        endView.stage=stage;//这里将主舞台赋值给静态舞台
        stage.setTitle("学生管理系统");
        stage.setResizable(false);
        otherView.login();
        endView.stage.show();
    }

    public static void main(String[] args) {
        launch(args);
    }

}

 登录界面和提示窗口(otherView):

//设置登录界面
    public static void login() {
        //创建网格面板
        GridPane gp=new GridPane();
        gp.setVgap(10);
        gp.setHgap(10);
        //创建标签
        Label idL=new Label("id");
        Label passwordL=new Label("密码");
        //创建输入框
        TextField tf=new TextField();
        PasswordField pf=new PasswordField();
        tf.setPromptText("请输入您的id号");
        pf.setPromptText("请输入6位数密码");
        //创建单选按钮
        RadioButton stuB=new RadioButton("学生");
        RadioButton teaB=new RadioButton("管理员");
        //创建单选按钮组
        ToggleGroup tg=new ToggleGroup();
        stuB.setToggleGroup(tg);
        teaB.setToggleGroup(tg);

        //创建单行面板
        HBox hBox1=new HBox();
        hBox1.setAlignment(Pos.CENTER);
        hBox1.setSpacing(10);
        hBox1.getChildren().addAll(stuB,teaB);
        //创建登录注册按钮
        Button loginB=new Button("登录");

        //给单选按钮组添加监听事件
        tg.selectedToggleProperty().addListener(((observableValue, toggle, t1) -> {
            if(t1.equals(stuB)){
                idL.setText("id");
            }else if(t1.equals(teaB)){
                idL.setText("姓名");

            }
        }));

        loginB.setOnAction(actionEvent -> {
            // 如果内容不为空
            try {
                String idS=tf.getText().trim();
                String passwordS=pf.getText().trim();
                Toggle selectedToggle = tg.getSelectedToggle(); // 获取选中的单选按钮
                if (selectedToggle != null && selectedToggle.equals(stuB)) { // 检查选中的按钮是否为学生按钮
                    if (studentDao.login(idS,passwordS)) {
                        studentView.stu_login(Integer.parseInt(idS));
                    }else if((idS.isEmpty()||passwordS.isEmpty())){
                        tipJframe("id或密码不能为空");
                    }else{
                        tipJframe("id或密码输入错误");
                    }
                }
                else if(selectedToggle !=null && selectedToggle.equals(teaB)){
                    if(judgeDao.magLogin(idS,passwordS)){
                        magView.mag_login();
                    }else  if((idS.isEmpty()||passwordS.isEmpty())){
                        tipJframe("姓名或密码不可为空");
                    }else {
                        tipJframe("姓名或密码输入错误");
                    }
                }else {
                    tipJframe("你是什么人");
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        });

        HBox hBox2=new HBox();
        hBox2.setAlignment(Pos.CENTER);
        hBox2.setSpacing(10);
        hBox2.getChildren().add(loginB);
        //将节点添加到面板当中
        gp.add(idL,0,0);
        gp.add(passwordL,0,1);
        gp.add(tf,1,0);
        gp.add(pf,1,1);
        gp.add(hBox1,1,2);
        gp.add(hBox2,1,3);
        gp.setAlignment(Pos.BASELINE_LEFT);
        //设置面板内边距
        gp.setPadding(new Insets(40,20,10,70));
        //设置面板垂直间距
        gp.setVgap(16);
        Scene scene=new Scene(gp,360,240);
        endView.stage.setScene(scene);

    }
    //增加弹出界面
    public static void tipJframe(String str){
        Label label=new Label(str);
        Button rebackB=new Button("返回");
        VBox vBox=new VBox(label,rebackB);
        vBox.setSpacing(10);
        vBox.setAlignment(Pos.CENTER);
        Scene scene=new Scene(vBox,150,100);
        Stage stage1=new Stage();
        stage1.setScene(scene);
        stage1.setTitle("提示");
        stage1.show();
        rebackB.setOnAction(actionEvent -> {
            stage1.close();
        });

    }

学生:

学生界面(studentView):

下面是我写的三个界面,和上面学生登录的图片对照,一共对应三个方法,当然后面两个方法(成绩查询和信息查询)会放到第一个stu_login的方法当中,根据按钮的动作监听而起作用

//学生登录后界面
    public static void stu_login(int stu_Id){
        Label label=new Label("学生查询系统");
        Button informationB=new Button("个人信息");
        Button gradeB=new Button("成绩查询");
        Button returnLogin=new Button("返回登录");

        //设置按钮字体颜色
        informationB.setTextFill(Color.BLUE);
        gradeB.setTextFill(Color.BLUE);
        returnLogin.setTextFill(Color.BLUE);

        //设置字体样式
        Font font = Font.font("Comic Sans MS", FontWeight.BOLD, FontPosture.REGULAR, 20);
        label.setFont(font);
        informationB.setFont(font);
        gradeB.setFont(font);
        returnLogin.setFont(font);

        //为按钮添加监听事件
        //信息查询
        informationB.setOnAction(actionEvent -> {
            try {
                informationInquire(stu_Id);
            } catch (Exception e) {
                e.printStackTrace();
            }
        });
        //成绩查询
        gradeB.setOnAction(actionEvent -> {
            try {
                gradeInquire(stu_Id);
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });
        //返回登录
        returnLogin.setOnAction(actionEvent -> otherView.login());

        //添加竖直方向面板
        VBox vBox=new VBox(20,label,informationB,gradeB,returnLogin);
        vBox.setAlignment(Pos.CENTER);
        Scene scene=new Scene(vBox,400,300);
        endView.stage.setScene(scene);

    }
    //学生信息查询
    public static void informationInquire(int stu_Id) throws Exception {
        //调用inquiry的返回值student
        student student= studentDao.returnStudent(stu_Id);
        Label idL=new Label("学号:"+student.getStu_id());
        Label classL=new Label("班级:"+student.getStu_class());
        Label nameL=new Label("姓名:"+student.getStu_name());
        Label genderL=new Label("性别:"+student.getStu_gender());
        Label birthL=new Label("出生日期:"+student.getStu_birth());
        Label majorL=new Label("专业:"+student.getStu_major());
        //设置字体样式
        Font font = Font.font("Comic Sans MS", FontWeight.BOLD, FontPosture.REGULAR, 20);
        idL.setFont(font);
        classL.setFont(font);
        nameL.setFont(font);
        genderL.setFont(font);
        birthL.setFont(font);
        majorL.setFont(font);

        Button backB=new Button("返回");
        backB.setOnAction(actionEvent -> {
            stu_login(stu_Id);
        });

        VBox vBox=new VBox(10);
        vBox.getChildren().addAll(idL,classL,nameL,genderL,birthL,majorL,backB);
        vBox.setAlignment(Pos.CENTER);
        vBox.setSpacing(10);
        Scene scene=new Scene(vBox,360,340);
        endView.stage.setScene(scene);

    }
    //学生成绩查询
    public static void gradeInquire(int stu_Id) throws Exception {
        int grade=studentDao.gradeOneself(stu_Id);
        Label gradeL=new Label("您的总学分为:"+grade);
        Font font = Font.font("Comic Sans MS", FontWeight.BOLD, FontPosture.REGULAR, 20);
        gradeL.setFont(font);
        VBox vBox=new VBox();
        vBox.setAlignment(Pos.CENTER);
        vBox.setPadding(new Insets(0,0,20,0));
        Button back=new Button("返回");
        back.setMinWidth(50);
        back.setMinHeight(30);
        back.setOnAction(actionEvent -> {
            stu_login(stu_Id);
        });
        vBox.getChildren().addAll(gradeL,back);
        Scene scene=new Scene(vBox,340,150);
        endView.stage.setScene(scene);
    }

学生Dao语句:

utilDao:

private static final String URL = "jdbc:mysql:///studentMs";
    private static final String USER = "root";
    private static final String PASSWORD = "123321";

    //获取连接对象
    public static Connection getCon() {
        try {
            return DriverManager.getConnection(URL, USER, PASSWORD);
        } catch (SQLException e) {
            e.printStackTrace();
            return null;
        }

    }

    //关闭资源
    public static void close(ResultSet rs, PreparedStatement ps, Connection con) {

        try {
            if (rs != null) {
                rs.close();
            }
            if (ps != null) {
                ps.close();
            }
            if (con != null) {
                con.close();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }

    }

    //执行mysql
    public static boolean exeUpdate(String sql, Object... params) {
        //获取连接对象
        Connection con = getCon();
        PreparedStatement ps = null;
        try {
            //获取编译对象
            ps = con.prepareStatement(sql);
            //判断参数是否为空
            if (Objects.nonNull(params)) {
                for (int i = 0; i < params.length; i++) {
                    //实现占位赋值
                    ps.setObject(i + 1, params[i]);
                }
            }
            //执行更新
            return ps.executeUpdate() > 0;
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            close(null, ps, con);
        }
        return false;
    }

studentDao*:

上面只展示了关于学生登录的jdbc语句,而不是我的studentDao中的所有语句,这样写是为让思路更加清晰,如果觉得很简单可以看我下面的总代码

//学生登录判断
    public static boolean login(String idStr, String passwordStr) throws Exception {

        String sql = "select * from student where stuID =? and stuPassword=?";
        PreparedStatement ps = utilDao.getCon().prepareStatement(sql);
        ps.setString(1,idStr);
        ps.setString(2, passwordStr);
        ResultSet rs = ps.executeQuery();

        if (rs.next()) {
            utilDao.close(rs,ps, utilDao.getCon());
            return true;
        } else {
            utilDao.close(rs,ps,utilDao.getCon());
            return false;
        }


    }

    //学生查询自己成绩
    public static Integer gradeOneself(int stu_id) throws Exception {
        String sql = "SELECT SUM(credit) AS gradesum FROM score WHERE stuID=?";

        try (Connection connection =utilDao.getCon();
             PreparedStatement ps = connection.prepareStatement(sql)) {

            ps.setInt(1, stu_id);
            try (ResultSet rs = ps.executeQuery()) {
                if (rs.next()) {
                    int gradesum = rs.getInt("gradesum");
                    return gradesum;
                } else {
                    // 如果没有查询到结果,可以返回 null 或者其他合适的值
                    return null;
                }
            }
        }
    }

    //返回学生信息
    public static student returnStudent(int stu_id)throws Exception{

        student student=new student();
        String sql="select stuID,stuClass,stuName,stuSex,stuBirth,stuMajor,stuPassword from student where stuID=?";
        PreparedStatement ps=utilDao.getCon().prepareStatement(sql);
        //过滤其他的只留下ID为1的学生
        ps.setString(1,String.valueOf(stu_id));
        ResultSet rs=ps.executeQuery();
        if(rs.next()){
            student.setStu_id(rs.getInt("stuID"));
            student.setStu_class(rs.getString("stuClass"));
            student.setStu_name(rs.getString("stuName"));
            student.setStu_gender(rs.getString("stuSex"));
            student.setStu_birth(rs.getString("stuBirth"));
            student.setStu_major(rs.getString("stuMajor"));
            student.setStu_password(rs.getString("stuPassword"));
        }
        rs.close();
        ps.close();
        return student;
    }
    

--- 关于学生登录的代码就这些 ---

管理员:

管理员界面(magView):

下面是我关于管理员设置的界面方法,一共四个管理员的主界面,和页面展示中管理员登录的前四个相对应,下面一共7个方法,关于createTableView方法就是我写的用我的student等的对象添加到tableview中的一部分代码,只是拿出来重新定义了一个方法,大家不用在意,所以其他的四个创建界面的方法刚好与页面展示中管理员登录的前四个相对应,第一个是登录后的界面方法,后三个是登录后的面板中前三个的按钮的动作监听所调用的方法

 //管理员登录界面
    public static void mag_login(){
        Label magL=new Label("管理员查询系统");
        VBox vBox=new VBox();
        vBox.setAlignment(Pos.CENTER);
        vBox.setSpacing(30);
        Button informationB= new Button("查询学生信息");
        Button courseB=new Button("查看课程");
        Button gradeB=new Button("查看学生成绩");
        Button rebackB=new Button("返回登录界面");
        rebackB.setOnAction(actionEvent -> {
            otherView.login();
        });
        informationB.setOnAction(actionEvent -> {
            try {
                magStudent();
            } catch (Exception e) {
                e.printStackTrace();
            }
        });

        courseB.setOnAction(actionEvent -> {
            try {
                magCourse();
            } catch (Exception e) {
                e.printStackTrace();
            }
        });
        gradeB.setOnAction(actionEvent -> {
            try {
                magScore();
            } catch (Exception e) {
                e.printStackTrace();
            }
        });
        rebackB.setOnAction(actionEvent -> {
            try {
                otherView.login();
            } catch (Exception e) {
                e.printStackTrace();
            }
        });
        Font font = Font.font("Comic Sans MS", FontWeight.BOLD, FontPosture.REGULAR, 20);
        magL.setFont(font);
        informationB.setFont(font);
        courseB.setFont(font);
        gradeB.setFont(font);
        rebackB.setFont(font);
        magL.setTextFill(Color.BLACK);
        informationB.setTextFill(Color.BLUE);
        courseB.setTextFill(Color.BLUE);
        gradeB.setTextFill(Color.BLUE);
        rebackB.setTextFill(Color.BLUE);
        vBox.getChildren().addAll(magL,informationB,courseB,gradeB,rebackB);
        Scene scene=new Scene(vBox,360,400);
        endView.stage.setScene(scene);


    }

    //管理员查看学生信息界面
    public static void magStudent() throws Exception {
        BorderPane bp=new BorderPane();

        TableView<student> tableView = createTableView1();

        Label studentL=new Label("学生信息管理");
        Button addB=new Button("添加学生");
        Button updateB=new Button("修改学生");
        Button deleteB=new Button("删除学生");
        Button backB=new Button("返回");
        addB.setOnAction(actionEvent -> {
            try {
                studentUtil.studentAdd();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });
        updateB.setOnAction(actionEvent -> {
            try {
                studentUtil.studentUpdate();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });
        deleteB.setOnAction(actionEvent -> {
            try {
                studentUtil.studentDelete();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });
        backB.setOnAction(actionEvent -> {
            mag_login();
        });

        addB.setMinWidth(70);
        updateB.setMinWidth(70);
        deleteB.setMinWidth(70);
        addB.setMinHeight(35);
        updateB.setMinHeight(35);
        deleteB.setMinHeight(35);
        addB.setTextFill(Color.INDIANRED);
        updateB.setTextFill(Color.INDIANRED);
        deleteB.setTextFill(Color.INDIANRED);
        backB.setTextFill(Color.INDIANRED);
        addB.setBorder(Border.stroke(Color.LIGHTPINK));
        updateB.setBorder(Border.stroke(Color.LIGHTPINK));
        deleteB.setBorder(Border.stroke(Color.LIGHTPINK));
        backB.setBorder(Border.stroke(Color.LIGHTPINK));
        backB.setOnAction(actionEvent -> {
            mag_login();
        });
        Font font = Font.font("Comic Sans MS", FontWeight.BOLD, FontPosture.REGULAR, 20);
        studentL.setFont(font);
        studentL.setTextFill(Color.RED);

        VBox vBox=new VBox();
        vBox.getChildren().addAll(studentL,addB,updateB,deleteB,backB);
        vBox.setAlignment(Pos.CENTER);
        vBox.setSpacing(20);
        vBox.setPadding(new Insets(50));

        BorderPane bp1=new BorderPane();
        bp1.setTop(vBox);
        BorderPane bp2=new BorderPane();
        bp2.setRight(tableView);

        // 获取学生列表,将集合转换成ObservableList
        ArrayList<student> students = studentDao.initStudent();
        // 将学生列表转换为ObservableList
        ObservableList<student> stuObs = FXCollections.observableArrayList(students);
        // 将 ObservableList 设置为 TableView 的数据源
        tableView.setItems(stuObs);


        bp.setLeft(bp1);
        bp.setCenter(bp2);

        Scene scene = new Scene(bp, 650, 350);
        endView.stage.setScene(scene);

    }
    //绑定学生面板
    public static TableView<student> createTableView1() {

        TableView<student> tableView = new TableView<>();

        TableColumn<student, Integer> idCol = new TableColumn<>("ID");
        idCol.setCellValueFactory(cellData -> new SimpleIntegerProperty(cellData.getValue().getStu_id()).asObject());

        TableColumn<student, String> classCol = new TableColumn<>("班级");
        classCol.setCellValueFactory(cellData -> new SimpleStringProperty(cellData.getValue().getStu_class()));

        TableColumn<student, String> nameCol = new TableColumn<>("姓名");
        nameCol.setCellValueFactory(cellData -> new SimpleStringProperty(cellData.getValue().getStu_name()));

        TableColumn<student, String> sexCol = new TableColumn<>("性别");
        sexCol.setCellValueFactory(cellData -> new SimpleStringProperty(cellData.getValue().getStu_gender()));

        TableColumn<student, String> birthCol = new TableColumn<>("出生日期");
        birthCol.setCellValueFactory(cellData -> new SimpleStringProperty(cellData.getValue().getStu_birth()));

        TableColumn<student, String> majorCol = new TableColumn<>("所在班级");
        majorCol.setCellValueFactory(cellData -> new SimpleStringProperty(cellData.getValue().getStu_major()));

        // 添加其他表格列...

        tableView.getColumns().addAll(idCol, classCol, nameCol,sexCol,birthCol,majorCol);

        return tableView;
    }

    //管理员查看课程界面
    public static void magCourse() throws Exception {
        //创建面板
        BorderPane bp=new BorderPane();
        //创建第二面板
        TableView<course> tableView = createTableView2();

        Label studentL=new Label("学生课程管理");
        Button addB=new Button("添加课程");
        Button updateB=new Button("修改课程");
        Button deleteB=new Button("删除课程");
        Button backB=new Button("返回");
        addB.setOnAction(actionEvent -> {
            try {
                courseUtil.courseAdd();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });
        updateB.setOnAction(actionEvent -> {
            courseUtil.courseUpdate();
        });
        deleteB.setOnAction(actionEvent -> {
            courseUtil.courseDelete();
        });
        backB.setOnAction(actionEvent -> {
            mag_login();
        });

        addB.setMinWidth(70);
        updateB.setMinWidth(70);
        deleteB.setMinWidth(70);
        addB.setMinHeight(35);
        updateB.setMinHeight(35);
        deleteB.setMinHeight(35);
        addB.setTextFill(Color.INDIANRED);
        updateB.setTextFill(Color.INDIANRED);
        deleteB.setTextFill(Color.INDIANRED);
        backB.setTextFill(Color.INDIANRED);
        addB.setBorder(Border.stroke(Color.LIGHTPINK));
        updateB.setBorder(Border.stroke(Color.LIGHTPINK));
        deleteB.setBorder(Border.stroke(Color.LIGHTPINK));
        backB.setBorder(Border.stroke(Color.LIGHTPINK));

        Font font = Font.font("Comic Sans MS", FontWeight.BOLD, FontPosture.REGULAR, 20);
        studentL.setFont(font);
        studentL.setTextFill(Color.RED);

        VBox vBox=new VBox();
        vBox.getChildren().addAll(studentL,addB,updateB,deleteB,backB);
        vBox.setAlignment(Pos.CENTER);
        vBox.setSpacing(20);
        vBox.setPadding(new Insets(50));

        BorderPane bp1=new BorderPane();
        bp1.setTop(vBox);
        BorderPane bp2=new BorderPane();
        bp2.setRight(tableView);

        // 获取学生列表
        ArrayList<course> courses = courseDao.initCourse();
        // 将学生列表转换为ObservableList
        ObservableList<course> stuObs = FXCollections.observableArrayList(courses);
        // 将 ObservableList 设置为 TableView 的数据源
        tableView.setItems(stuObs);

        bp.setLeft(bp1);
        bp.setCenter(bp2);
        Scene scene = new Scene(bp, 700, 350);
        endView.stage.setScene(scene);

    }
    //绑定课程面板
    public static TableView<course> createTableView2() {

        TableView<course> tableView = new TableView<>();

        TableColumn<course, Integer> idCol = new TableColumn<>("课程号");
        idCol.setCellValueFactory(cellData -> new SimpleIntegerProperty(cellData.getValue().getCou_id()).asObject());

        TableColumn<course, String> majorCol = new TableColumn<>("所属专业");
        majorCol.setCellValueFactory(cellData -> new SimpleStringProperty(cellData.getValue().getCou_major()));

        TableColumn<course, String> nameCol = new TableColumn<>("课程名称");
        nameCol.setCellValueFactory(cellData -> new SimpleStringProperty(cellData.getValue().getCou_name()));

        TableColumn<course, String> typeCol = new TableColumn<>("课程类型");
        typeCol.setCellValueFactory(cellData -> new SimpleStringProperty(cellData.getValue().getCou_type()));

        TableColumn<course, String> beginCol = new TableColumn<>("开课学期");
        beginCol.setCellValueFactory(cellData -> new SimpleStringProperty(cellData.getValue().getCou_beginTime()));

        TableColumn<course, Integer> studyCol = new TableColumn<>("学时数");
        studyCol.setCellValueFactory(cellData -> new SimpleIntegerProperty(cellData.getValue().getCou_studyTime()).asObject());

        TableColumn<course, Integer> scoreCol = new TableColumn<>("学分");
        scoreCol.setCellValueFactory(cellData -> new SimpleIntegerProperty(cellData.getValue().getCou_score()).asObject());


        tableView.getColumns().addAll(idCol, majorCol, nameCol,typeCol,beginCol,studyCol,scoreCol);

        return tableView;
    }

    //管理员查看学生成绩界面
    public static void magScore() throws Exception {
        BorderPane bp=new BorderPane();
        TableView<score> tableView = createTableView3();

        Label studentL=new Label("学生成绩管理");
        Button addB=new Button("添加成绩");
        Button updateB=new Button("修改成绩");
        Button deleteB=new Button("删除成绩");
        Button rebackB=new Button("返回");
        addB.setOnAction(actionEvent -> {
            scoreUtil.scoreAdd();
        });
        updateB.setOnAction(actionEvent -> {
            scoreUtil.scoreUpdate();
        });

        deleteB.setOnAction(actionEvent -> {
            scoreUtil.scoreDelete();
        });
        rebackB.setOnAction(actionEvent -> {
            mag_login();
        });


        addB.setMinWidth(70);
        updateB.setMinWidth(70);
        deleteB.setMinWidth(70);
        addB.setMinHeight(35);
        updateB.setMinHeight(35);
        deleteB.setMinHeight(35);
        addB.setTextFill(Color.INDIANRED);
        updateB.setTextFill(Color.INDIANRED);
        deleteB.setTextFill(Color.INDIANRED);
        rebackB.setTextFill(Color.INDIANRED);
        addB.setBorder(Border.stroke(Color.LIGHTPINK));
        updateB.setBorder(Border.stroke(Color.LIGHTPINK));
        deleteB.setBorder(Border.stroke(Color.LIGHTPINK));
        rebackB.setBorder(Border.stroke(Color.LIGHTPINK));
        Font font = Font.font("Comic Sans MS", FontWeight.BOLD, FontPosture.REGULAR, 20);
        studentL.setFont(font);
        studentL.setTextFill(Color.RED);

        VBox vBox=new VBox();
        vBox.getChildren().addAll(studentL,addB,updateB,deleteB,rebackB);
        vBox.setAlignment(Pos.CENTER);
        vBox.setSpacing(10);
        vBox.setPadding(new Insets(40));

        BorderPane bp1=new BorderPane();
        bp1.setTop(vBox);
        BorderPane bp2=new BorderPane();
        bp2.setRight(tableView);

        // 获取学生列表
        ArrayList<score> scores = scoreDao.initScore();
        // 将学生列表转换为ObservableList
        ObservableList<score> stuObs = FXCollections.observableArrayList(scores);
        // 将 ObservableList 设置为 TableView 的数据源
        tableView.setItems(stuObs);

        bp.setLeft(bp1);
        bp.setCenter(bp2);

        Scene scene = new Scene(bp, 450, 300);
        endView.stage.setScene(scene);

    }
    //绑定成绩面板
    public static TableView<score> createTableView3() {

        TableView<score> tableView = new TableView<>();

        TableColumn<score, Integer> stuCol = new TableColumn<>("学号");
        stuCol.setCellValueFactory(cellData -> new SimpleIntegerProperty(cellData.getValue().getScore_id()).asObject());

        TableColumn<score, Integer> idCol = new TableColumn<>("课程号");
        idCol.setCellValueFactory(cellData -> new SimpleIntegerProperty(cellData.getValue().getScore_cid()).asObject());

        TableColumn<score, String> studyCol = new TableColumn<>("学数");
        studyCol.setCellValueFactory(cellData -> new SimpleStringProperty(cellData.getValue().getSocre_score()));

        TableColumn<score, String> scoreCol = new TableColumn<>("学分");
        scoreCol.setCellValueFactory(cellData -> new SimpleStringProperty(cellData.getValue().getScore_credit()));

        tableView.getColumns().addAll(stuCol,idCol,studyCol,scoreCol);

        return tableView;
    }
}

管理员工具类:

管理员工具类是对进入操作页面中的添加学生,修改学生,删除学生,添加课程...的操作


学生(studentUtil):

    //添加学生信息
    public static void studentAdd() throws Exception {
        //添加面板
        GridPane gp=new GridPane();
        Label idL=new Label("学号");
        Label classL=new Label("班级");
        Label nameL=new Label("姓名");
        Label sexL=new Label("性别");
        Label birthL=new Label("出生日期");
        Label majorL=new Label("所在专业");
        Label passwordL=new Label("密码");
        //添加按钮
        Button admitB=new Button("提交");
        Button backB=new Button("返回");
        //设置字体样式
        Font font = Font.font("Comic Sans MS", FontWeight.BOLD, FontPosture.REGULAR, 15);
        idL.setFont(font);
        classL.setFont(font);
        nameL.setFont(font);
        sexL.setFont(font);
        birthL.setFont(font);
        majorL.setFont(font);
        //添加输入框
        TextField idT=new TextField(String.valueOf(judgeDao.maxID()+1));
        TextField classT=new TextField();
        TextField nameT=new TextField();
        TextField sexT=new TextField();
        TextField birthT=new TextField();
        TextField majorT=new TextField();
        TextField passwordT=new TextField();
        //将组件添加到面板当中
        gp.add(idL,0,0);
        gp.add(idT,1,0);
        gp.add(classL,0,1);
        gp.add(classT,1,1);
        gp.add(nameL,0,2);
        gp.add(nameT,1,2);
        gp.add(sexL,0,3);
        gp.add(sexT,1,3);
        gp.add(birthL,0,4);
        gp.add(birthT,1,4);
        gp.add(majorL,0,5);
        gp.add(majorT,1,5);
        gp.add(passwordL,0,6);
        gp.add(passwordT,1,6);
        gp.add(admitB,0,7);
        gp.add(backB,1,7);
        //设置面板样式
        gp.setPadding(new Insets(30));
        gp.setVgap(20);
        gp.setHgap(10);
        Scene scene=new Scene(gp,300,400);
        Stage stage=new Stage();
        stage.setScene(scene);
        stage.setTitle("添加学生信息");
        stage.show();
        backB.setOnAction(actionEvent -> {
            try {
                stage.close();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });
        //给提交按钮添加监听事件
        admitB.setOnAction(actionEvent -> {
            try {
                // 获取文本框中的内容并去除首尾空白
                String id = idT.getText().trim();
                String clazz = classT.getText().trim();
                String name = nameT.getText().trim();
                String sex = sexT.getText().trim();
                String birth = birthT.getText().trim();
                String major = majorT.getText().trim();
                String password = passwordT.getText().trim();

                // 首先进行基本的非空验证,如果有任何一个字段为空,则不进行添加操作
                if (id.isEmpty() || clazz.isEmpty() || name.isEmpty() || sex.isEmpty() || birth.isEmpty() || major.isEmpty() || password.isEmpty()) {
                    otherView.tipJframe("字段不能为空");
                    return;
                }else if(!((sex.equals("男")||sex.equals("女")))){
                    otherView.tipJframe("请输入正常性别");
                    return;
                }else if(!judgeUtil.isValidDate(birth)){
                    otherView.tipJframe("日期格式不正确,请重新输入");
                    return;
                }else if(!clazz.equals(judgeUtil.isClass(id))){
                    otherView.tipJframe("班级格式不正确,请重新输入");
                    return;
                }else if(!password.equals(judgeUtil.isPassword(id))){
                    otherView.tipJframe("密码格式错误,请重新输入");
                    return;
                }
                int studentId = Integer.parseInt(id);

                // 调用Dao层方法尝试添加学生信息
                if (studentDao.addStudent(studentId, clazz, name, sex, birth, major, password)) {
                    // 添加成功后的操作
                    studentDao.initStudent();
                    magView.magStudent();
                    otherView.tipJframe("添加成功");
                }else {
                    otherView.tipJframe("添加失败");
                }
            } catch (Exception e) {
                // 捕获其他异常并打印堆栈信息
                e.printStackTrace();
                otherView.tipJframe("操作失败:" + e.getMessage()); // 提示操作失败,并显示具体的异常信息
            }
        });

    }
    //修改学生信息
    public static void studentUpdate(){

        //创建第一个面板
        GridPane gp = new GridPane();
        Label idl = new Label("ID");
        TextField idt = new TextField();

        //创建第一个界面的按钮
        Button admitb = new Button("提交");
        Button backb = new Button("返回");

        gp.add(idl,0,0);
        gp.add(idt,1,0);
        gp.add(admitb,0,1);
        gp.add(backb,0,2);
        gp.setHgap(20);
        gp.setVgap(10);
        gp.setAlignment(Pos.CENTER);
        Scene scene=new Scene(gp,240,140);
        //创建第一个舞台
        Stage stage=new Stage();
        stage.setScene(scene);
        stage.setResizable(false);
        stage.setTitle("修改学生信息");
        stage.show();
        backb.setOnAction(actionEvent -> {
            try {
                stage.close();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });

        // 创建第二个舞台
        Stage stage1 = new Stage();

        //创建只能存储一个字符的字符串
        final int[] id = new int[1];
        final String[] clas = new String[1];
        final String[] names = new String[1];
        final String[] sexs = new String[1];
        final String[] births = new String[1];
        final String[] majors = new String[1];
        final String[] passwords=new String[1];

        GridPane gp1=new GridPane();
        Label idL=new Label("学号");
        Label classL=new Label("班级");
        Label nameL=new Label("姓名");
        Label sexL=new Label("性别");
        Label birthL=new Label("出生日期");
        Label majorL=new Label("所在专业");
        Label passwordL=new Label("密码");

        Button admitB=new Button("提交");
        Button rebackB=new Button("返回");
        rebackB.setOnAction(actionEvent -> {
            stage1.close();
        });

        //创建显示信息文本框
        TextField idT=new TextField(String.valueOf(id[0]));
        TextField classT=new TextField(clas[0]);
        TextField nameT=new TextField(names[0]);
        TextField sexT=new TextField(sexs[0]);
        TextField birthT=new TextField(births[0]);
        TextField majorT=new TextField(majors[0]);
        TextField passwordT=new TextField(passwords[0]);

        Font font = Font.font("Comic Sans MS", FontWeight.BOLD, FontPosture.REGULAR, 15);
        idL.setFont(font);
        classL.setFont(font);
        nameL.setFont(font);
        sexL.setFont(font);
        birthL.setFont(font);
        majorL.setFont(font);


        gp1.add(idL,0,0);
        gp1.add(idT,1,0);
        gp1.add(classL,0,1);
        gp1.add(classT,1,1);
        gp1.add(nameL,0,2);
        gp1.add(nameT,1,2);
        gp1.add(sexL,0,3);
        gp1.add(sexT,1,3);
        gp1.add(birthL,0,4);
        gp1.add(birthT,1,4);
        gp1.add(majorL,0,5);
        gp1.add(majorT,1,5);
        gp1.add(passwordL,0,6);
        gp1.add(passwordT,1,6);
        gp1.add(admitB,0,7);
        gp1.add(rebackB,1,7);

        gp1.setPadding(new Insets(30));
        gp1.setVgap(20);
        gp1.setHgap(10);
        Scene scene1=new Scene(gp1,300,400);
        stage1.setScene(scene1);
        stage1.setResizable(false);
        stage1.setTitle("修改学生信息");
        stage1.close();

        //第一个界面的提交按钮
        admitb.setOnAction(actionEvent -> {
            String idText = idt.getText().trim();
            if (!idText.isEmpty()) {
                try {
                    if (studentDao.isStudent(Integer.parseInt(idText))) {
                        endView.student0=studentDao.returnStudent(Integer.parseInt(idText));
                        id[0] = endView.student0.getStu_id();
                        clas[0] = endView.student0.getStu_class();
                        names[0] = endView.student0.getStu_name();
                        sexs[0] = endView.student0.getStu_gender();
                        births[0] = endView.student0.getStu_birth();
                        majors[0] = endView.student0.getStu_major();
                        passwords[0]=endView.student0.getStu_password();

                        // 将值设置到文本框中
                        idT.setText(String.valueOf(id[0]));
                        classT.setText(clas[0]);
                        nameT.setText(names[0]);
                        sexT.setText(sexs[0]);
                        birthT.setText(births[0]);
                        majorT.setText(majors[0]);
                        passwordT.setText(passwords[0]);

                        // 显示舞台
                        stage1.show();
                    } else {
                        otherView.tipJframe("不存在该学生");
                    }
                } catch (Exception e) {
                    throw new RuntimeException(e);
                }
            } else {
                otherView.tipJframe("ID不能为空");
            }
        });

        //第二个界面的提交按钮
        admitB.setOnAction(actionEvent -> {
            try {
                String idd = idT.getText().trim();
                String clazz = classT.getText().trim();
                String name = nameT.getText().trim();
                String sex = sexT.getText().trim();
                String birth = birthT.getText().trim();
                String major = majorT.getText().trim();
                String password=passwordT.getText().trim();

                // 首先进行基本的非空验证,如果有任何一个字段为空,则不进行添加操作
                if (idd.isEmpty() || clazz.isEmpty() || name.isEmpty() || sex.isEmpty() || birth.isEmpty() || major.isEmpty()) {
                    otherView.tipJframe("所有字段不能为空");
                    return;
                }else if(!((sex.equals("男")||sex.equals("女")))){
                    otherView.tipJframe("请输入正常性别");
                    return;
                }else if(!judgeUtil.isValidDate(birth)){
                    otherView.tipJframe("日期格式不正确,请重新输入");
                    return;
                }else if(!clazz.equals(judgeUtil.isClass(idd))){
                    otherView.tipJframe("班级格式不正确,请重新输入");
                    return;
                }else if(!password.equals(judgeUtil.isPassword(idd))){
                    otherView.tipJframe("密码格式错误,请重新输入");
                    return;
                }
                int studentId = Integer.parseInt(idd);
                //判断如果学号发生改变,则进行添加学生操作,否者进行修改操作
                //如果发生修改
                if(id[0]!=Integer.valueOf(idT.getText().trim())){
                    if (studentDao.addStudent(studentId, clazz, name, sex, birth, major,password)) {
                        // 添加成功后的操作
                        if(studentDao.deleteStudent(id[0])){
                            studentDao.initStudent();
                            magView.magStudent();
                            otherView.tipJframe("修改成功");
                        }
                    } else {
                        otherView.tipJframe("修改失败");
                    }
                }
                //如果没有发生修改,那么进行修改操作
                else {
                    if (studentDao.updateStudent(studentId, clazz, name, sex, birth, major,password)) {
                        // 添加成功后的操作
                        studentDao.initStudent();
                        magView.magStudent();
                        otherView.tipJframe("修改成功");
                    } else {
                        otherView.tipJframe("修改失败");
                    }
                }
            } catch (Exception e) {
                e.printStackTrace();
                otherView.tipJframe("操作失败:" + e.getMessage());
            }
        });

    }
    //删除学生信息
    public static void studentDelete(){
        GridPane gp = new GridPane();
        Label idL = new Label("ID");
        TextField idT = new TextField();
        Button admitB = new Button("提交");
        Button backB = new Button("返回");

        // 将按钮事件处理移到这里,确保在点击按钮时获取最新的文本框内容

        gp.add(idL, 0, 0);
        gp.add(idT, 1, 0);
        gp.add(admitB, 0, 1);
        gp.add(backB, 1, 1);
        gp.setAlignment(Pos.CENTER);
        gp.setHgap(10);
        gp.setVgap(30);
        //创建一个删除学生的界面舞台
        Stage stage = new Stage();
        Scene scene = new Scene(gp, 240, 100);
        stage.setScene(scene);
        stage.setTitle("删除学生信息");
        stage.setResizable(false);
        stage.show();
        //如果舞台退出,则界面关闭
        backB.setOnAction(actionEvent -> {
            try {
                stage.close();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });
        //对按钮添加点击事件
        admitB.setOnAction(actionEvent -> {
            String ids = idT.getText().trim();
            if (!ids.isEmpty()) {
                try {
                    int id = Integer.parseInt(ids);
                    if (studentDao.isStudent(id)) {
                        if (studentDao.deleteStudent(id)) {
                            otherView.tipJframe("学生删除成功");
                            //更新数据库信息
                            studentDao.initStudent();
                            //更新面板信息
                            magView.magStudent();
                        } else {
                            otherView.tipJframe("学生删除失败");
                        }
                    } else {
                        otherView.tipJframe("未找到该学生");
                    }
                } catch (NumberFormatException e) {
                    otherView.tipJframe("请输入有效的数字ID");
                } catch (Exception e) {
                    e.printStackTrace();
                    otherView.tipJframe("数据库操作失败");
                }
            } else {
                otherView.tipJframe("请输入学生ID");
            }
        });

    }

课程(courseUtil):


    //添加课程
    public static void courseAdd() throws Exception {
        //创建面板
        GridPane gp=new GridPane();
        Label cIDL=new Label("课程号");
        Label cMajorL=new Label("所属专业");
        Label cNameL=new Label("课程名称");
        Label cTypeL=new Label("课程类型");
        Label cBeginL=new Label("开课学期");
        Label cStudyL=new Label("学时数");
        Label cCreditL=new Label("学分");
        //创建按钮
        Button admitB=new Button("提交");
        Button backB=new Button("返回");
        //创建字体样式
        Font font = Font.font("Comic Sans MS", FontWeight.BOLD, FontPosture.REGULAR, 15);
        cIDL.setFont(font);
        cMajorL.setFont(font);
        cNameL.setFont(font);
        cTypeL.setFont(font);
        cBeginL.setFont(font);
        cStudyL.setFont(font);
        cCreditL.setFont(font);
        //创建文本输入框
        TextField cIDT=new TextField(String.valueOf(judgeDao.maxcID()+1));
        TextField cMajorT=new TextField();
        TextField cNameT=new TextField();
        TextField cTypeT=new TextField();
        TextField cBeginT=new TextField();
        TextField cStudyT=new TextField();
        TextField cCreditT=new TextField();
        //将节点添加到面板当中
        gp.add(cIDL,0,0);
        gp.add(cIDT,1,0);
        gp.add(cMajorL,0,1);
        gp.add(cMajorT,1,1);
        gp.add(cNameL,0,2);
        gp.add(cNameT,1,2);
        gp.add(cTypeL,0,3);
        gp.add(cTypeT,1,3);
        gp.add(cBeginL,0,4);
        gp.add(cBeginT,1,4);
        gp.add(cStudyL,0,5);
        gp.add(cStudyT,1,5);
        gp.add(cCreditL,0,6);
        gp.add(cCreditT,1,6);
        gp.add(admitB,0,7);
        gp.add(backB,1,7);
        //设置面板
        gp.setPadding(new Insets(30));
        gp.setVgap(20);
        gp.setHgap(10);
        Scene scene=new Scene(gp,350,400);
        Stage stage=new Stage();
        stage.setResizable(false);
        stage.setTitle("添加课程");
        stage.setScene(scene);
        stage.show();
        backB.setOnAction(actionEvent -> {
            try {
                stage.close();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });
        admitB.setOnAction(actionEvent -> {
            try {
                // 获取文本框中的内容并去除首尾空白
                String id = cIDT.getText().trim();
                String major = cMajorT.getText().trim();
                String name = cNameT.getText().trim();
                String type = cTypeT.getText().trim();
                String begin = cBeginT.getText().trim();
                String study = cStudyT.getText().trim();
                String credit = cCreditT.getText().trim();

                // 首先进行基本的非空验证,如果有任何一个字段为空,则不进行添加操作
                if ((id.isEmpty() || major.isEmpty() || name.isEmpty() || type.isEmpty() || begin.isEmpty() || study.isEmpty() || credit.isEmpty())) {
                    otherView.tipJframe("字段不能为空");
                    return;
                }
                // 尝试将id和password转换为整数,如果格式不正确会抛出NumberFormatException
                int cId = Integer.parseInt(id);
                int studytime=Integer.parseInt(study);
                int creditt=Integer.parseInt(credit);

                if (courseDao.addCourse(cId, major, name, type, begin, studytime, creditt)) {
                    // 添加成功后的操作
                    courseDao.initCourse();
                    magView.magCourse();
                    otherView.tipJframe("课程添加成功");
                } else {
                    otherView.tipJframe("课程添加失败");
                }
            } catch (Exception e) {
                // 捕获其他异常并打印堆栈信息
                e.printStackTrace();
                otherView.tipJframe("操作失败:" + e.getMessage());
            }
        });

    }
    //修改课程
    public static void courseUpdate(){
        //创建第一个面板
        GridPane gp = new GridPane();
        Label idl = new Label("cID");
        TextField idt = new TextField();
        //创建第一个界面的按钮
        Button admitb = new Button("提交");
        Button backB = new Button("返回");

        gp.add(idl,0,0);
        gp.add(idt,1,0);
        gp.add(admitb,0,1);
        gp.add(backB,0,2);
        gp.setHgap(20);
        gp.setVgap(10);
        gp.setAlignment(Pos.CENTER);
        Scene scene=new Scene(gp,250,140);
        Stage stage=new Stage();
        stage.setTitle("修改课程");
        stage.setScene(scene);
        stage.show();
        backB.setOnAction(actionEvent -> {
            try {
                stage.close();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });

        //第二个舞台
        Stage stage1 = new Stage();

        //创建只能存储一个字符串的数组
        final int[] id = new int[1];
        final String[] major = new String[1];
        final String[] name = new String[1];
        final String[] type = new String[1];
        final String[] begin = new String[1];
        final int[] studytime = new int[1];
        final int[] credit = new int[1];

        // 创建显示信息文本框
        TextField idT = new TextField(String.valueOf(id[0]));
        TextField majorT = new TextField(major[0]);
        TextField nameT = new TextField(name[0]);
        TextField typeT = new TextField(type[0]);
        TextField beginT = new TextField(begin[0]);
        TextField studyTime = new TextField(String.valueOf(studytime[0]));
        TextField creditT = new TextField(String.valueOf(credit[0]));

        //创建第二个面板
        GridPane gp1=new GridPane();
        Label cID=new Label("课程号");
        Label cMajor=new Label("所属专业");
        Label cName=new Label("课程名称");
        Label cType=new Label("课程类型");
        Label cBegin=new Label("开课学期");
        Label cStudy=new Label("学时数");
        Label cCredit=new Label("学分");

        Button admitB=new Button("提交");
        Button rebackB=new Button("返回");
        rebackB.setOnAction(actionEvent -> {
            try {
                stage1.close();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });
        //创建字体样式
        Font font = Font.font("Comic Sans MS", FontWeight.BOLD, FontPosture.REGULAR, 15);
        cID.setFont(font);
        cMajor.setFont(font);
        cName.setFont(font);
        cType.setFont(font);
        cBegin.setFont(font);
        cStudy.setFont(font);
        cCredit.setFont(font);


        gp1.add(cID,0,0);
        gp1.add(idT,1,0);
        gp1.add(cMajor,0,1);
        gp1.add(majorT,1,1);
        gp1.add(cName,0,2);
        gp1.add(nameT,1,2);
        gp1.add(cType,0,3);
        gp1.add(typeT,1,3);
        gp1.add(cBegin,0,4);
        gp1.add(beginT,1,4);
        gp1.add(cStudy,0,5);
        gp1.add(studyTime,1,5);
        gp1.add(cCredit,0,6);
        gp1.add(creditT,1,6);
        gp1.add(admitB,0,7);
        gp1.add(rebackB,1,7);

        gp1.setPadding(new Insets(30));
        gp1.setVgap(20);
        gp1.setHgap(10);
        Scene scene1=new Scene(gp1,300,400);
        stage1.setScene(scene1);
        stage1.setTitle("修改课程");
        stage1.setResizable(false);
        stage1.close();

        String idText = idt.getText().trim();
        //创建第一个按钮的点击事件
        admitb.setOnAction(actionEvent -> {

            if (idText.isEmpty()) {
                otherView.tipJframe("id不能为空");
            }
            else {
                try {
                    if (courseDao.isCourse(Integer.parseInt(idText))) {
                        endView.course0 = courseDao.returnCourse(Integer.parseInt(idText));
                        //给数组字符串赋值
                        id[0] = endView.course0.getCou_id();
                        major[0] = endView.course0.getCou_major();
                        name[0] = endView.course0.getCou_name();
                        type[0] = endView.course0.getCou_type();
                        begin[0] = endView.course0.getCou_beginTime();
                        studytime[0] = endView.course0.getCou_studyTime();
                        credit[0] = endView.course0.getCou_score();

                        // 更新界面元素,确保在JavaFX应用线程上更新
                        Platform.runLater(() -> {
                            idT.setText(String.valueOf(id[0]));
                            majorT.setText(major[0]);
                            nameT.setText(name[0]);
                            typeT.setText(type[0]);
                            beginT.setText(begin[0]);
                            studyTime.setText(String.valueOf(studytime[0]));
                            creditT.setText(String.valueOf(credit[0]));
                        });
                        // 显示舞台
                        stage1.show();
                    } else {
                        otherView.tipJframe("不存在该课程");
                    }
                } catch (Exception e) {
                    otherView.tipJframe("发生异常: " + e.getMessage());
                }
            }
        });
        //创建第二个面板的按钮的点击事件
        admitB.setOnAction(actionEvent -> {
            try {
                // 获取文本框中的内容并去除首尾空白
                String ids = idT.getText().trim();
                String majors = majorT.getText().trim();
                String names = nameT.getText().trim();
                String types = typeT.getText().trim();
                String begins = beginT.getText().trim();
                String studys = studyTime.getText().trim();
                String credits = creditT.getText().trim();

                // 首先进行基本的非空验证,如果有任何一个字段为空,则不进行添加操作
                if (ids.isEmpty() || majors.isEmpty() || names.isEmpty() || types.isEmpty() || begins.isEmpty() || studys.isEmpty() || credits.isEmpty()) {
                    otherView.tipJframe("字段不能为空");
                    return;
                }
                int cId = Integer.parseInt(ids);
                int study=Integer.parseInt(studys);
                int creditt=Integer.parseInt(credits);

                if(!(id[0]==Integer.valueOf(idText))){
                    if(courseDao.addCourse(cId, majors, names, types, begins, study, creditt)){
                        courseDao.deleteCourse(id[0]);
                        courseDao.initCourse();
                        magView.magCourse();
                        otherView.tipJframe("课程修改成功");
                    }else {
                        // 添加失败的提示
                        otherView.tipJframe("课程修改失败");
                    }
                }else if(id[0]==Integer.valueOf(idText)){
                    // 调用Dao层方法尝试添加学生信息
                    if (courseDao.updateCourse(cId, majors, names, types, begins, study, creditt)) {
                        // 添加成功后的操作
                        courseDao.initCourse();
                        magView.magCourse();
                        otherView.tipJframe("课程修改成功");
                    } else {
                        // 添加失败的提示
                        otherView.tipJframe("课程修改失败");
                    }
                }

            } catch (Exception e) {
                e.printStackTrace();
                otherView.tipJframe("操作失败:" + e.getMessage()); // 提示操作失败,并显示具体的异常信息
            }
        });


    }
    //删除课程
    public static void courseDelete(){
        GridPane gp = new GridPane();
        Label idL = new Label("ID");
        TextField idT = new TextField();
        Button admitB = new Button("提交");
        Button backB = new Button("返回");

        gp.add(idL, 0, 0);
        gp.add(idT, 1, 0);
        gp.add(admitB, 0, 1);
        gp.add(backB, 1, 1);
        gp.setAlignment(Pos.CENTER);
        gp.setHgap(10);
        gp.setVgap(30);

        Stage stage = new Stage();
        Scene scene = new Scene(gp, 240, 100);
        stage.setTitle("删除课程");
        stage.setScene(scene);
        stage.show();
        backB.setOnAction(actionEvent -> {
            try {
                stage.close();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });

        // 将按钮事件处理移到这里,确保在点击按钮时获取最新的文本框内容
        admitB.setOnAction(actionEvent -> {
            String ids = idT.getText().trim(); // 获取文本框内容
            if (!ids.isEmpty()) {
                try {
                    int id = Integer.parseInt(ids);
                    if (courseDao.isCourse(id)) {
                        if (courseDao.deleteCourse(id)) {
                            otherView.tipJframe("课程删除成功");
                            courseDao.initCourse(); // 更新数据
                            magView.magCourse(); // 刷新界面信息
                        } else {
                            otherView.tipJframe("课程删除失败");
                        }
                    } else {
                        otherView.tipJframe("未找到该课程");
                    }
                } catch (Exception e) {
                    e.printStackTrace();
                    otherView.tipJframe("数据库操作失败");
                }
            } else {
                otherView.tipJframe("请输入课程ID");
            }
        });

    }

分数(scoreUtil):

    //添加成绩
    public static void scoreAdd(){
        GridPane gp=new GridPane();
        Label sID=new Label("学号");
        Label sCID=new Label("课程号");
        Label sStudy=new Label("成绩");
        Label sCredit=new Label("学分");

        Button admitB=new Button("提交");
        Button rebackB=new Button("返回");

        Font font = Font.font("Comic Sans MS", FontWeight.BOLD, FontPosture.REGULAR, 15);
        sID.setFont(font);
        sCID.setFont(font);
        sStudy.setFont(font);
        sCredit.setFont(font);

        TextField sIDT=new TextField();
        TextField scIDT=new TextField();
        TextField sStudyT=new TextField();
        TextField sCreditT=new TextField();

        gp.add(sID,0,0);
        gp.add(sIDT,1,0);
        gp.add(sCID,0,1);
        gp.add(scIDT,1,1);
        gp.add(sStudy,0,2);
        gp.add(sStudyT,1,2);
        gp.add(sCredit,0,3);
        gp.add(sCreditT,1,3);
        gp.add(admitB,0,7);
        gp.add(rebackB,1,7);

        gp.setPadding(new Insets(30));
        gp.setVgap(20);
        gp.setHgap(10);
        Scene scene=new Scene(gp,280,300);
        Stage stage1=new Stage();
        stage1.setScene(scene);
        stage1.setTitle("添加分数");
        stage1.show();
        rebackB.setOnAction(actionEvent -> {
            try {
                stage1.close();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });
        admitB.setOnAction(actionEvent -> {
            try {
                // 获取文本框中的内容并去除首尾空白
                String id = sIDT.getText().trim();
                String cid = scIDT.getText().trim();
                String study = sStudyT.getText().trim();
                String credit = sCreditT.getText().trim();

                // 首先进行基本的非空验证,如果有任何一个字段为空,则不进行添加操作
                if ((id.isEmpty() || cid.isEmpty() || study.isEmpty() || credit.isEmpty())) {
                    otherView.tipJframe("字段不能为空");
                    return;
                }else if(!studentDao.isStudent(Integer.parseInt(id))){
                    otherView.tipJframe("不存在该学生");
                    return;
                }else if(!courseDao.isCourse(Integer.parseInt(cid))){
                    otherView.tipJframe("不存在该课程");
                    return;
                }
                int Id=Integer.parseInt(id);
                int cId = Integer.parseInt(cid);
                if (scoreDao.addScore(Id, cId, study, credit)&&scoreDao.isScore(Id,cId)) {
                    scoreDao.initScore();
                    magView.magScore();
                    otherView.tipJframe("成绩添加成功");
                } else {
                    // 添加失败的提示
                    otherView.tipJframe("成绩添加失败");
                }
            } catch (NumberFormatException e) {
                otherView.tipJframe("ID格式错误,请输入有效的整数");
            } catch (Exception e) {
                // 捕获其他异常并打印堆栈信息
                e.printStackTrace();
                otherView.tipJframe("操作失败:" + e.getMessage());
            }
        });

    }
    //修改成绩
    public static void scoreUpdate(){
        GridPane gp=new GridPane();

        Label idl = new Label("ID");
        Label cidl=new Label("cID");
        TextField idt = new TextField();
        TextField cidt=new TextField();

        Button admitb = new Button("提交");
        Button backB=new Button("返回");

        gp.add(idl,0,0);
        gp.add(idt,1,0);
        gp.add(cidl,0,1);
        gp.add(cidt,1,1);
        gp.add(admitb,0,2);
        gp.add(backB,1,2);
        gp.setHgap(10);
        gp.setVgap(20);
        gp.setAlignment(Pos.CENTER);
        Scene scene=new Scene(gp,300,240);
        //创建第一个舞台
        Stage stage=new Stage();
        stage.setScene(scene);
        stage.setResizable(false);
        stage.setTitle("修改分数");
        stage.show();
        backB.setOnAction(actionEvent -> {
            stage.close();
        });

        //创建第二个面板
        GridPane gp1 = new GridPane();

        final int[] id = new int[1];
        final int[] cid = new int[1];

        TextField sIDT=new TextField(String.valueOf(id[0]));
        TextField scIDT=new TextField(String.valueOf(cid[0]));
        TextField sStudyT=new TextField();
        TextField sCreditT=new TextField();

        Label sID=new Label("学号");
        Label sCID=new Label("课程号");
        Label sStudy=new Label("成绩");
        Label sCredit=new Label("学分");

        Button admitB=new Button("提交");
        Button rebackB=new Button("返回");

        Font font = Font.font("Comic Sans MS", FontWeight.BOLD, FontPosture.REGULAR, 15);
        sID.setFont(font);
        sCID.setFont(font);
        sStudy.setFont(font);
        sCredit.setFont(font);

        gp1.add(sID,0,0);
        gp1.add(sIDT,1,0);
        gp1.add(sCID,0,1);
        gp1.add(scIDT,1,1);
        gp1.add(sStudy,0,2);
        gp1.add(sStudyT,1,2);
        gp1.add(sCredit,0,3);
        gp1.add(sCreditT,1,3);
        gp1.add(admitB,0,7);
        gp1.add(rebackB,1,7);

        gp1.setPadding(new Insets(30));
        gp1.setVgap(20);
        gp1.setHgap(10);
        Scene scene1=new Scene(gp1,280,300);
        //创建第二个舞台
        Stage stage1 = new Stage();
        stage1.setScene(scene1);
        stage1.setTitle("修改分数");
        stage1.setResizable(false);
        stage1.close();
        rebackB.setOnAction(actionEvent -> {
            try {
                stage1.close();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });

        // 登录按钮的事件处理器
        admitb.setOnAction(actionEvent -> {
            String idText = idt.getText().trim();
            String cidText = cidt.getText().trim();

            if (!(idText.isEmpty() || cidText.isEmpty())) {
                try {
                    if (judgeUtil.isDigits(idText) && judgeUtil.isDigits(cidText)) {
                        if (scoreDao.isScore(Integer.parseInt(idText), Integer.parseInt(cidText))) {
                            endView.score0 = scoreDao.returnScore(Integer.parseInt(idText),Integer.parseInt(cidText));
                            id[0] = endView.score0.getScore_id();
                            cid[0] = endView.score0.getScore_cid();

                            // 更新TextField显示
                            sIDT.setText(String.valueOf(id[0]));
                            scIDT.setText(String.valueOf(cid[0]));

                            // 显示舞台
                            stage1.show();
                            stage.close();
                        } else if (!studentDao.isStudent(Integer.parseInt(idText))) {
                            otherView.tipJframe("不存在该学生");
                        } else if (!courseDao.isCourse(Integer.parseInt(cidText))) {
                            otherView.tipJframe("不存在该课程");
                        } else {
                            otherView.tipJframe("信息输入错误");
                        }
                    } else {
                        otherView.tipJframe("格式错误");
                    }
                } catch (Exception e) {
                    throw new RuntimeException(e);
                }
            } else {
                otherView.tipJframe("id不能为空");
            }
        });
        //第二个按钮点击事件
        admitB.setOnAction(actionEvent -> {
            try {
                // 获取文本框中的内容并去除首尾空白
                String ids = sIDT.getText().trim();
                String cids = scIDT.getText().trim();
                String studys = sStudyT.getText().trim();
                String credits = sCredit.getText().trim();

                // 首先进行基本的非空验证,如果有任何一个字段为空,则不进行添加操作
                if (ids.isEmpty() || cids.isEmpty() || studys.isEmpty() || credits.isEmpty()) {
                    otherView.tipJframe("字段不能为空");
                    return;
                }
                // 尝试将id和password转换为整数,如果格式不正确会抛出NumberFormatException
                int Id=Integer.parseInt(ids);
                int cId = Integer.parseInt(cids);
                // 调用Dao层方法尝试添加学生信息
                if (scoreDao.updateScore(Id, cId, studys, credits)) {
                    // 添加成功后的操作
                    scoreDao.initScore();
                    magView.magScore();
                    otherView.tipJframe("成绩添加成功");
                } else {
                    otherView.tipJframe("成绩添加失败");
                }
            } catch (NumberFormatException e) {
                otherView.tipJframe("ID格式错误,请输入有效的整数");
            } catch (Exception e) {
                e.printStackTrace();
                otherView.tipJframe("操作失败:" + e.getMessage());
            }
        });

    }
    //删除成绩
    public static void scoreDelete(){
        GridPane gp = new GridPane();
        Label idL = new Label("ID");
        Label cidL=new Label("cID");
        TextField idT = new TextField();
        TextField cidT=new TextField();
        Button admitB = new Button("提交");
        Button backB = new Button("返回");

        gp.add(idL, 0, 0);
        gp.add(idT, 1, 0);
        gp.add(cidL,0,1);
        gp.add(cidT,1,1);
        gp.add(admitB, 0, 2);
        gp.add(backB, 1, 2);
        gp.setAlignment(Pos.CENTER);
        gp.setHgap(10);
        gp.setVgap(30);

        Stage stage = new Stage();
        Scene scene = new Scene(gp, 240, 200);
        stage.setScene(scene);
        stage.setTitle("删除分数");
        stage.show();
        backB.setOnAction(actionEvent -> {
            try {
                stage.close();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });
        // 将按钮事件处理移到这里,确保在点击按钮时获取最新的文本框内容
        admitB.setOnAction(actionEvent -> {
            String ids = idT.getText().trim();
            String cids=cidT.getText().trim();
            if (!ids.isEmpty()) {
                try {
                    int id = Integer.parseInt(ids);
                    int cid=Integer.parseInt(cids);
                    if (studentDao.isStudent(id)) {
                        if (scoreDao.deleteScore(id,cid)) {
                            otherView.tipJframe("课程删除成功");
                            scoreDao.initScore();
                            magView.magScore();
                        } else {
                            otherView.tipJframe("课程删除失败");
                        }
                    } else {
                        otherView.tipJframe("未找到该课程");
                    }
                } catch (NumberFormatException e) {
                    otherView.tipJframe("请输入有效的数字ID");
                } catch (Exception e) {
                    e.printStackTrace();
                    otherView.tipJframe("数据库操作失败");
                }
            } else {
                otherView.tipJframe("请输入课程ID");
            }
        });


    }

判断工具类(judgeUtil):

这个工具类是对添加数据时一些文本框内字符串的判断,是在上面三个util中要用到的

 //判断日期格式
    public static boolean isValidDate(String dateStr) {
        try {
            DateTimeFormatter.ofPattern("yyyy-MM-dd").parse(dateStr);
            return true;
        } catch (DateTimeParseException e) {
            return false;
        }
    }
    //判断班级格式
    public static String isClass(String s){
        String numberString = s;
        int numberOfCharsToTake = 6; // 指定你想截取的字符数量
        String prefix = numberString.substring(0, numberOfCharsToTake);
        return prefix;
    }
    //判断密码格式
    public static String isPassword(String s){
        String numberString = s;
        int numberOfCharsToTake = 6; // 指定你想截取的字符数量从末尾开始
        int startIndex = numberString.length() - numberOfCharsToTake;
        String suffix = numberString.substring(startIndex);
        return suffix;
    }
    //判断字符串是否为数字
    public static boolean isDigits(String str) {
        return str.matches("\\d+");
    }

管理员Dao类:

utilDao:


由于Connection,close,exeupdate会被经常用到,所以在这里我就直接写成三个方法了

private static final String URL = "jdbc:mysql:///studentMs";
    private static final String USER = "root";
    private static final String PASSWORD = "123321";

    //获取连接对象
    public static Connection getCon() {
        try {
            return DriverManager.getConnection(URL, USER, PASSWORD);
        } catch (SQLException e) {
            e.printStackTrace();
            return null;
        }

    }

    //关闭资源
    public static void close(ResultSet rs, PreparedStatement ps, Connection con) {

        try {
            if (rs != null) {
                rs.close();
            }
            if (ps != null) {
                ps.close();
            }
            if (con != null) {
                con.close();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }

    }

    //执行mysql
    public static boolean exeUpdate(String sql, Object... params) {
        //获取连接对象
        Connection con = getCon();
        PreparedStatement ps = null;
        try {
            //获取编译对象
            ps = con.prepareStatement(sql);
            //判断参数是否为空
            if (Objects.nonNull(params)) {
                for (int i = 0; i < params.length; i++) {
                    //实现占位赋值
                    ps.setObject(i + 1, params[i]);
                }
            }
            //执行更新
            return ps.executeUpdate() > 0;
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            close(null, ps, con);
        }
        return false;
    }

studentDao*:

下面的studentDao只与管理员的界面操作有关

 //返回学生信息
    public static student returnStudent(int stu_id)throws Exception{

        student student=new student();
        String sql="select stuID,stuClass,stuName,stuSex,stuBirth,stuMajor,stuPassword from student where stuID=?";
        PreparedStatement ps=utilDao.getCon().prepareStatement(sql);
        //过滤其他的只留下ID为1的学生
        ps.setString(1,String.valueOf(stu_id));
        ResultSet rs=ps.executeQuery();
        if(rs.next()){
            student.setStu_id(rs.getInt("stuID"));
            student.setStu_class(rs.getString("stuClass"));
            student.setStu_name(rs.getString("stuName"));
            student.setStu_gender(rs.getString("stuSex"));
            student.setStu_birth(rs.getString("stuBirth"));
            student.setStu_major(rs.getString("stuMajor"));
            student.setStu_password(rs.getString("stuPassword"));
        }
        rs.close();
        ps.close();
        return student;
    }

    //判断是否存在该学生
    public static boolean isStudent(int stu_id) throws SQLException {
        String sql="select stuID,stuClass,stuName,stuSex,stuBirth,stuMajor from student where stuID=?";
        PreparedStatement ps=utilDao.getCon().prepareStatement(sql);
        //过滤其他的只留下ID为1的学生
        ps.setString(1,String.valueOf(stu_id));
        ResultSet rs=ps.executeQuery();
        if(rs.next()){
            return true;
        }
        else {
            return false;
        }
    }

    // 学生类信息初始化
    public static ArrayList<student> initStudent() throws Exception {
        ArrayList<student> students = new ArrayList<>();
        String sql = "select * from student order by stuID asc";
        PreparedStatement ps = utilDao.getCon().prepareStatement(sql);
        ResultSet rs = ps.executeQuery();

        // 使用 while 循环遍历 ResultSet 中的所有行
        while (rs.next()) {
            student student = new student();
            student.setStu_id(rs.getInt("stuID"));
            student.setStu_class(rs.getString("stuClass"));
            student.setStu_name(rs.getString("stuName"));
            student.setStu_gender(rs.getString("stuSex"));
            student.setStu_birth(rs.getString("stuBirth"));
            student.setStu_major(rs.getString("stuMajor"));
            students.add(student);
        }

        // 关闭资源
        rs.close();
        ps.close();
        return students;
    }
    //添加学生
    public static boolean addStudent(int stuId,String stuClass,String stuName, String stuSex, String stuBirth, String stuMajor,String stuPassword)throws Exception{
        String sql="insert into student(stuID,stuClass,stuName,stuSex,stuBirth,stuMajor,stuPassword )values (?,?,?,?,?,?,?) ";
        return utilDao.exeUpdate(sql,stuId,stuClass,stuName,stuSex,stuBirth,stuMajor,stuPassword);
    }
    //修改学生
    public static boolean updateStudent(int stuId,String stuClass,String stuName, String stuSex, String stuBirth, String stuMajor,String stuPassword)throws Exception{
        String sql="update student set stuID=?,stuClass=?,stuName=?,stuSex=?,stuBirth=?,stuMajor=?,stuPassword=?";
        return utilDao.exeUpdate(sql,stuId,stuClass,stuName,stuSex,stuBirth,stuMajor,stuPassword);
    }
    //删除学生
    public static boolean deleteStudent(int stuId){
        String sql="delete from student where stuID=?";
        return utilDao.exeUpdate(sql,stuId);
    }

courseDao:

//返回课程
    public static course returnCourse(int cID)throws Exception{

        course course=new course();
        String sql="select cID,cMajor,cName,cType,cStartTerm,cPeriod,cCredit from course where cID=?";
        PreparedStatement ps=utilDao.getCon().prepareStatement(sql);
        //过滤其他的只留下ID为1的学生
        ps.setString(1,String.valueOf(cID));
        ResultSet rs=ps.executeQuery();
        if(rs.next()){
            course.setCou_id(rs.getInt("cID"));
            course.setCou_major(rs.getString("cMajor"));
            course.setCou_name(rs.getString("cName"));
            course.setCou_type(rs.getString("cType"));
            course.setCou_beginTime(rs.getString("cStartTerm"));
            course.setCou_studyTime(rs.getInt("cPeriod"));
            course.setCou_score(rs.getInt("cCredit"));
        }
        rs.close();
        ps.close();
        return course;
    }
    //判断是否存在该课程
    public static boolean isCourse(int cID) throws Exception {
        String sql="select cID,cMajor,cName,cType,cStartTerm,cPeriod,cCredit from course where cID=?";
        PreparedStatement ps=utilDao.getCon().prepareStatement(sql);
        //过滤其他的只留下ID为1的学生
        ps.setInt(1,cID);
        ResultSet rs=ps.executeQuery();
        if(rs.next()){
            return true;
        } else {
            return false;
        }
    }

    // 学生类集合课程初始化
    public static ArrayList<course> initCourse() throws Exception {
        ArrayList<course> courses = new ArrayList<>();
        String sql = "select * from course order by cID asc";
        PreparedStatement ps = utilDao.getCon().prepareStatement(sql);
        ResultSet rs = ps.executeQuery();

        // 使用 while 循环遍历 ResultSet 中的所有行
        while (rs.next()) {
            course course = new course();
            course.setCou_id(rs.getInt("cID"));
            course.setCou_major(rs.getString("cMajor"));
            course.setCou_name(rs.getString("cName"));
            course.setCou_type(rs.getString("cType"));
            course.setCou_beginTime(rs.getString("cStartTerm"));
            course.setCou_studyTime(rs.getInt("cPeriod"));
            course.setCou_score(rs.getInt("cCredit"));

            courses.add(course);
        }

        // 关闭资源
        rs.close();
        ps.close();
        return courses;
    }
    //增加课程
    public static boolean addCourse(int cID, String cMajor, String cName, String cType, String cStartTerm, int  cPeriod, int  cCredit){
        String sql="insert into course(cID,cMajor,cName,cType,cStartTerm,cPeriod,cCredit)values (?,?,?,?,?,?,?) ";
        return utilDao.exeUpdate(sql,cID,cMajor,cName,cType,cStartTerm,cPeriod,cCredit);

    }
    //修改课程
    public static boolean updateCourse(int cID, String cMajor, String cName, String cType, String cStartTerm, int  cPeriod, int cCredit){
        String sql="update course set cID=?,cMajor=?,cName=?,cType=?,cStartTerm=?,cPeriod=?,cCredit=? ";
        return utilDao.exeUpdate(sql,cID,cMajor,cName,cType,cStartTerm,cPeriod,cCredit);

    }
    //删除课程
    public static boolean deleteCourse(int cID){
        String sql="delete from course where cID=?";
        return utilDao.exeUpdate(sql,cID);
    }

scoreDao:

//判断是否存在该成绩
    public static boolean isScore(int stu_id,int cid) throws SQLException {
        String sql="select * from score where stuID=? and cID=?";
        PreparedStatement ps=utilDao.getCon().prepareStatement(sql);
        //过滤其他的只留下ID为1的学生
        ps.setString(1,String.valueOf(stu_id));
        ps.setString(2,String.valueOf(cid));
        ResultSet rs=ps.executeQuery();
        if(rs.next()){
            return true;
        }
        return false;
    }

    // 学生类成绩初始化
    public static ArrayList<score> initScore() throws Exception {
        ArrayList<score> scores = new ArrayList<>();
        String sql = "select * from score order by stuID asc ";
        PreparedStatement ps = utilDao.getCon().prepareStatement(sql);
        ResultSet rs = ps.executeQuery();

        // 使用 while 循环遍历 ResultSet 中的所有行
        while (rs.next()) {
            score score = new score();
            score.setScore_id(rs.getInt("stuID"));
            score.setScore_cid(rs.getInt("cID"));
            score.setSocre_score(rs.getString("score"));
            score.setScore_credit(rs.getString("credit"));
            scores.add(score);
        }

        // 关闭资源
        rs.close();
        ps.close();
        return scores;
    }

    //返回学生成绩
    public static score returnScore(int stuID,int cID)throws Exception{
        score score=new score();
        String sql="select * from score where stuID=? and cID=? ";
        PreparedStatement ps=utilDao.getCon().prepareStatement(sql);
        //过滤其他的只留下ID为1的学生
        ps.setString(1,String.valueOf(stuID));
        ps.setString(2,String.valueOf(cID));
        ResultSet rs=ps.executeQuery();
        while (rs.next()){
            score.setScore_id(rs.getInt("stuID"));
            score.setScore_cid(rs.getInt("cID"));
            score.setSocre_score(rs.getString("score"));
            score.setScore_credit(rs.getString("credit"));
        }
        rs.close();
        ps.close();
        return score;
    }

    //增加成绩
    public static boolean addScore(int stuID,int cID,String score,String credit){
        String sql="insert into score(stuID,cID,score,credit)values (?,?,?,?) ";
        return utilDao.exeUpdate(sql,stuID,cID,score,credit);
    }
    //修改成绩
    public static boolean updateScore(int stuID,int cID,String score,String credit){
        String sql="update score set stuID=?,cID=?,score=?,credit=? ";
        return utilDao.exeUpdate(sql,stuID,cID,score,credit);
    }
    //删除成绩
    public static boolean deleteScore(int stuID,int cID){
        String sql="delete from score where stuID=? and cID=?";
        return utilDao.exeUpdate(sql,stuID,cID);
    }

judgeDao:

//找出最大学生id
    public static int maxID() throws Exception {
        String sql = "select max(stuID) as maxId from student";
        PreparedStatement ps = utilDao.getCon().prepareStatement(sql);
        ResultSet rs = ps.executeQuery();
        // 默认值或者根据需求设定初始值
        int maxId = 0;
        //如果存在
        if (rs.next()) {
            maxId = rs.getInt("maxId"); // 从结果集中获取名为 maxId 的列的值
        }
        return maxId;

    }
    //找出最大课程id
    public static int maxcID()throws Exception{
        String sql = "select max(cID) as maxId from course";
        PreparedStatement ps = utilDao.getCon().prepareStatement(sql);
        ResultSet rs = ps.executeQuery();

        int maxId = 0; // 默认值或者根据需求设定初始值
        if (rs.next()) {
            maxId = rs.getInt("maxId"); // 从结果集中获取名为 maxId 的列的值
        }
        return maxId;
    }
    //判断是否为管理员
    public static boolean magLogin(String name,String password)throws Exception{
        String sql="select * from manager where name=? and password=?";
        PreparedStatement ps=utilDao.getCon().prepareStatement(sql);
        ps.setString(1,name);
        ps.setString(2,password);
        ResultSet rs=ps.executeQuery();

        if (rs.next()) {
            utilDao.close(rs,ps,utilDao.getCon());
            return true;
        } else {
            utilDao.close(rs,ps,utilDao.getCon());
            return false;
        }

    }

domain(对象类):

student:

public class student {

    private int stu_id;
    private String stu_class;
    private String stu_name;
    private String stu_gender;
    private String stu_birth;
    private String stu_major;
    private String stu_password;

    public student() {
    }

    public int getStu_id() {
        return stu_id;
    }

    public void setStu_id(int stu_id) {
        this.stu_id = stu_id;
    }

    public String getStu_class() {
        return stu_class;
    }

    public void setStu_class(String stu_class) {
        this.stu_class = stu_class;
    }

    public String getStu_name() {
        return stu_name;
    }

    public void setStu_name(String stu_name) {
        this.stu_name = stu_name;
    }

    public String getStu_gender() {
        return stu_gender;
    }

    public void setStu_gender(String stu_gender) {
        this.stu_gender = stu_gender;
    }

    public String getStu_birth() {
        return stu_birth;
    }

    public void setStu_birth(String stu_birth) {
        this.stu_birth = stu_birth;
    }

    public String getStu_major() {
        return stu_major;
    }

    public void setStu_major(String stu_major) {
        this.stu_major = stu_major;
    }

    public String getStu_password() {
        return stu_password;
    }

    public void setStu_password(String stu_password) {
        this.stu_password = stu_password;
    }

course:

public class course {

    private int cou_id;
    private String cou_major;
    private String cou_name;
    private String cou_type;
    private String cou_beginTime;
    private int cou_studyTime;
    private int cou_score;

    public course() {
    }

    public int getCou_id() {
        return cou_id;
    }
    public void setCou_id(int cou_id) {
        this.cou_id = cou_id;
    }

    public String getCou_major() {
        return cou_major;
    }

    public void setCou_major(String cou_major) {
        this.cou_major = cou_major;
    }

    public String getCou_name() {
        return cou_name;
    }

    public void setCou_name(String cou_name) {
        this.cou_name = cou_name;
    }

    public String getCou_type() {
        return cou_type;
    }

    public void setCou_type(String cou_type) {
        this.cou_type = cou_type;
    }

    public String getCou_beginTime() {
        return cou_beginTime;
    }

    public void setCou_beginTime(String cou_beginTime) {
        this.cou_beginTime = cou_beginTime;
    }

    public int getCou_studyTime() {
        return cou_studyTime;
    }

    public void setCou_studyTime(int cou_studyTime) {
        this.cou_studyTime = cou_studyTime;
    }

    public void setCou_score(int cou_score) {
        this.cou_score = cou_score;
    }

    public int getCou_score() {
        return cou_score;
    }

score:

private int score_id;
    private int score_cid;
    private String socre_score;
    private String score_credit;

    public score() {
    }

    public int getScore_id() {
        return score_id;
    }

    public String getSocre_score() {
        return socre_score;
    }

    public void setSocre_score(String socre_score) {
        this.socre_score = socre_score;
    }

    public String getScore_credit() {
        return score_credit;
    }

    public void setScore_credit(String score_credit) {
        this.score_credit = score_credit;
    }

    public void setScore_id(int score_id) {
        this.score_id = score_id;
    }

    public int getScore_cid() {
        return score_cid;
    }

结尾

我的代码到这里就分享完了,感谢大家的观看看到这里,由于我的代码结构比较多,这里关于上面的每一个类都是完整的,除了studentDao分开写了,我这里在重新展示一下我的studentDao代码,其他的都一样就不展示了

 

studentDao(完整):

//学生登录判断
    public static boolean login(String idStr, String passwordStr) throws Exception {

        String sql = "select * from student where stuID =? and stuPassword=?";
        PreparedStatement ps = utilDao.getCon().prepareStatement(sql);
        ps.setString(1,idStr);
        ps.setString(2, passwordStr);
        ResultSet rs = ps.executeQuery();

        if (rs.next()) {
            utilDao.close(rs,ps, utilDao.getCon());
            return true;
        } else {
            utilDao.close(rs,ps,utilDao.getCon());
            return false;
        }


    }

    //学生查询自己成绩
    public static Integer gradeOneself(int stu_id) throws Exception {
        String sql = "SELECT SUM(credit) AS gradesum FROM score WHERE stuID=?";

        try (Connection connection =utilDao.getCon();
             PreparedStatement ps = connection.prepareStatement(sql)) {

            ps.setInt(1, stu_id);
            try (ResultSet rs = ps.executeQuery()) {
                if (rs.next()) {
                    int gradesum = rs.getInt("gradesum");
                    return gradesum;
                } else {
                    // 如果没有查询到结果,可以返回 null 或者其他合适的值
                    return null;
                }
            }
        }
    }

    //返回学生信息
    public static student returnStudent(int stu_id)throws Exception{

        student student=new student();
        String sql="select stuID,stuClass,stuName,stuSex,stuBirth,stuMajor,stuPassword from student where stuID=?";
        PreparedStatement ps=utilDao.getCon().prepareStatement(sql);
        //过滤其他的只留下ID为1的学生
        ps.setString(1,String.valueOf(stu_id));
        ResultSet rs=ps.executeQuery();
        if(rs.next()){
            student.setStu_id(rs.getInt("stuID"));
            student.setStu_class(rs.getString("stuClass"));
            student.setStu_name(rs.getString("stuName"));
            student.setStu_gender(rs.getString("stuSex"));
            student.setStu_birth(rs.getString("stuBirth"));
            student.setStu_major(rs.getString("stuMajor"));
            student.setStu_password(rs.getString("stuPassword"));
        }
        rs.close();
        ps.close();
        return student;
    }

    //判断是否存在该学生
    public static boolean isStudent(int stu_id) throws SQLException {
        String sql="select stuID,stuClass,stuName,stuSex,stuBirth,stuMajor from student where stuID=?";
        PreparedStatement ps=utilDao.getCon().prepareStatement(sql);
        //过滤其他的只留下ID为1的学生
        ps.setString(1,String.valueOf(stu_id));
        ResultSet rs=ps.executeQuery();
        if(rs.next()){
            return true;
        }
        else {
            return false;
        }
    }

    // 学生类信息初始化
    public static ArrayList<student> initStudent() throws Exception {
        ArrayList<student> students = new ArrayList<>();
        String sql = "select * from student order by stuID asc";
        PreparedStatement ps = utilDao.getCon().prepareStatement(sql);
        ResultSet rs = ps.executeQuery();

        // 使用 while 循环遍历 ResultSet 中的所有行
        while (rs.next()) {
            student student = new student();
            student.setStu_id(rs.getInt("stuID"));
            student.setStu_class(rs.getString("stuClass"));
            student.setStu_name(rs.getString("stuName"));
            student.setStu_gender(rs.getString("stuSex"));
            student.setStu_birth(rs.getString("stuBirth"));
            student.setStu_major(rs.getString("stuMajor"));
            students.add(student);
        }

        // 关闭资源
        rs.close();
        ps.close();
        return students;
    }
    //添加学生
    public static boolean addStudent(int stuId,String stuClass,String stuName, String stuSex, String stuBirth, String stuMajor,String stuPassword)throws Exception{
        String sql="insert into student(stuID,stuClass,stuName,stuSex,stuBirth,stuMajor,stuPassword )values (?,?,?,?,?,?,?) ";
        return utilDao.exeUpdate(sql,stuId,stuClass,stuName,stuSex,stuBirth,stuMajor,stuPassword);
    }
    //修改学生
    public static boolean updateStudent(int stuId,String stuClass,String stuName, String stuSex, String stuBirth, String stuMajor,String stuPassword)throws Exception{
        String sql="update student set stuID=?,stuClass=?,stuName=?,stuSex=?,stuBirth=?,stuMajor=?,stuPassword=?";
        return utilDao.exeUpdate(sql,stuId,stuClass,stuName,stuSex,stuBirth,stuMajor,stuPassword);
    }
    //删除学生
    public static boolean deleteStudent(int stuId){
        String sql="delete from student where stuID=?";
        return utilDao.exeUpdate(sql,stuId);
    }

感谢大家的观看,如果有不懂的地方可以给我留言哦,冲! ! !

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1920589.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

浪潮服务器内存物理插槽位置

浪潮服务器内存物理插槽位置 如下图所示

在iPhone / iPad上轻松模拟GPS位置 AnyGo for Mac

在iPhone / iPad上轻松模拟GPS位置 AnyGo for Mac AnyGo for Mac是一款专为Mac电脑用户设计的虚拟定位工具。它可以模拟你的GPS位置&#xff0c;让你的设备显示你在任何世界上的任何地方。无论你是想在游戏中虚拟移动&#xff0c;还是在社交媒体上分享虚拟的旅行照片&#xff0…

基于SpringBoot+MySQL的租房项目+文档

&#x1f497;博主介绍&#x1f497;&#xff1a;✌在职Java研发工程师、专注于程序设计、源码分享、技术交流、专注于Java技术领域和毕业设计✌ 温馨提示&#xff1a;文末有 CSDN 平台官方提供的老师 Wechat / QQ 名片 :) Java精品实战案例《700套》 2025最新毕业设计选题推荐…

05 以物品与用户为基础个性化推荐算法的四大策略

《易经》&#xff1a;“九二&#xff1a;见龙在田&#xff0c;利见大人”。九二是指阳爻在卦中处于第二位&#xff0c;见龙指龙出现在地面上&#xff0c;开始崭露头角&#xff0c;但是仍须努力&#xff0c;应处于安于偏下的位置。 本节是模块二第一节&#xff0c;模块二讲解传…

从业务架构到应用架构技术剖析

从业务架构到应用架构 4A架构理论&#xff0c;一个企业级架构框架&#xff0c;将企业架构&#xff08;EA&#xff09;划分为四大核心领域&#xff0c;每个领域都聚焦于组织的不同维度。该理论提供了一种结构化的设计和理解企业运作方式的方法&#xff0c;确保技术解决方案能…

前端面试题53(在vue中history与hash区别)

在Vue.js应用中&#xff0c;路由&#xff08;routing&#xff09;是管理应用程序中不同页面&#xff08;视图&#xff09;的重要部分。Vue Router提供了两种路由模式来管理URL&#xff1a;hash模式和history模式。下面详细介绍这两种模式的区别&#xff1a; 1. Hash 模式 原理…

如何在idea安装git,使用gitee?

一、什么是git&#xff0c;git与gitee、GitHub的关系&#xff1f; 1.什么是git&#xff1f; Git 是一个开源的分布式版本控制系统&#xff0c;用于企业项目中程序员协同开发。 2.git与gitee、GitHub的关系是什么&#xff1f; git &#xff1a;Git是一种版本控制系统&#x…

Linux:NFS共享存储

目录 一、NFS基本概述 二、NFS共享文件实验 2.1、安装nfs和rpcbind软件 2.2、修改配置文件设置共享 2.3、创建共享目录 ​编辑 2.4、开启服务 2.5、客户端验证共享目录可访问 三、tcpdump命令 3.1、概述 3.2、简单表达 3.3、过滤规则 ​编辑 3.4、tcpdump常见参数…

Redis分布式锁在高并发环境下的超卖问题

先看这样一段代码&#xff0c;购买商品&#xff0c;扣减库存的逻辑代码 当用户下单&#xff0c;并且调用扣减库存的接口时&#xff0c;先判断商品库存是否还有&#xff0c;因为是秒杀场景下&#xff0c;太多请求都打到数据库&#xff0c;可能会导致数据库崩溃&#xff0c;所以…

[leetcode] largest-divisible-subset 最大整除子集

. - 力扣&#xff08;LeetCode&#xff09; class Solution { public:vector<int> largestDivisibleSubset(vector<int>& nums) {int len nums.size();sort(nums.begin(), nums.end());// 第 1 步&#xff1a;动态规划找出最大子集的个数、最大子集中的最大整…

Djngo项目创建的准备工作【5】

【 一 】搭建纯净模式 核心就是 在安装完drf之后记得在app里面注册rest_framework, # django 默认很多app--》很多表auth 6个表session 表content-type表 # django很多中间件 ​ # 以后我们的项目&#xff0c;可能不用这些东西---》由于带了内置app&#xff0c;这些表就会创建…

MaxViT : 多轴Vision Transformer

本文提出了一种高效、可扩展的多轴注意力模型,该模型包括两个方面:局部注意力被阻塞和全局注意力被扩张。这些设计选择允许在任意输入分辨率下的全局-局部空间交互,只有线性复杂度。还通过有效地将注意力模型与卷积混合在一起,提出了一个新的架构元素,并相应地提出了一个简…

IAR全面支持芯驰科技E3系列车规MCU产品E3119/E3118

中国上海&#xff0c;2024年7月11日 — 全球领先的嵌入式系统开发软件解决方案供应商IAR与全场景智能车芯引领者芯驰科技宣布进一步扩大合作&#xff0c;最新版IAR Embedded Workbench for Arm已全面支持芯驰科技的E3119/E3118车规级MCU产品。IAR与芯驰科技有着悠久的合作历史&…

强化学习实战3:Sarsa 与 Q-Learning 算法求解迷宫问题

前置知识 首先实验环境依然是我们之前说的迷宫环境&#xff0c;然后是一些基本术语&#xff0c;应该都是比较熟悉的&#xff1a; 强化学习的算法大概有两类&#xff0c;一类是策略迭代&#xff08;讲究的是策略 Π &#xff09;&#xff0c;还有一类是价值迭代&#xff0c;也就…

电脑 DNS 缓存是什么?如何清除?

DNS&#xff08;Domain Name System&#xff0c;域名系统&#xff09;是互联网的重要组成部分&#xff0c;负责将人类易记的域名转换为机器可读的 IP 地址&#xff0c;从而实现网络通信。DNS 缓存是 DNS 系统中的一个关键机制&#xff0c;通过临时存储已解析的域名信息&#xf…

lnmp+DISCUZ+WORDPRESS

lnmpDISCUZWORDPRESS lnmpDISCUZ&#xff08;论坛的一个服务&#xff09; l&#xff1a;linux操作系统 n&#xff1a;nginx前端页面的web服务 php&#xff1a;动态请求转发的中间件 mysql&#xff1a;数据库 保存用户和密码以及论坛的相关内容 mysql8.0.30安装&#xff1a…

微信综合购物商城小程序ui模板源码

微信电商小程序前端页面&#xff0c;综合购物商城ui界面模板。主要功能包含&#xff1a;电商主页、商品分类、购物车、购物车结算、我的个人中心管理、礼券、签到、新人专享、专栏、商品详情页、我的订单、我的余额、我的积分、我的收藏、我的地址、我的礼券等。这是一款非常齐…

单相整流-TI视频课笔记

目录 1、单相半波整流 1.1、单相半波----电容滤波---超轻负载 1.2、单相半波----电容滤波---轻负载 1.3、单相半波----电容滤波---重负载 2、全波整流 2.1、全波整流的仿真 2.2、半波与全波滤波的对比 3、全桥整流电路 3.1、全波和全桥整流对比 3.2、半波全波和全桥…

【Linux杂货铺】2.进程优先级

1.进程优先级基本概念 进程优先级是操作系统中用于确定进程调度顺序的一个指标。每个进程都会被分配一个优先级&#xff0c;优先级较高的进程会在调度时优先被执行。进程优先级的设定通常根据进程的重要性、紧急程度、资源需求等因素来确定。操作系统会根据进程的优先级来决定进…

出现 failed to remove xxxx: Invalid argument 解决方法

目录 前言1. 问题所示2. 原理分析3. 解决方法 前言 这好像是一个Git的一个Bug&#xff0c;对应有个下下策的解决方式 1. 问题所示 Git提交的时候出现如下问题 Git warning:failed to remove debug.log:invalid argumentgit clean -f -1 --F&#xff1a;\xxx failed to rem…