Java私活200元,完成JavaSwing学生成绩管理系统(三)

2022-09-02 18:11:07 浏览数 (1)

Java私活200元,完成JavaSwing学生成绩管理系统(三)

需求

接到一个需求,说让使用JavaSwing Mysql完成一个学生成绩管理系统,时间紧任务重。

具体需求如下:

用户需求

系统功能: 提供学生成绩的査询功能,输入学生的学号,能査找出该生各学期的成绩,并能够对成绩数据进行添加、删除、修改等基本操作和统计计算。

功能需求

1、功能1 提供学生成绩的査询功能,输入学生的学号,能査找出该生各学期的成绩

2、功能2 能对成绩数据进行添加、删除、修改等基本操作,并能进行一般的统计计算

3、功能3 建立学生成绩数据库,要求: 自定义数据库文件格式

需求分析

在别人眼中:要写java代码 还要写连接数据库代码 以及创建表、写注释 编写文档等等

在我的眼中:创建一个javaswing的项目并套用之前写好的学生成绩管理的各种属性,代码生成器勾选增删改查等条件,然后自动生成即可。

代码生成器实现原理

1.文件目录介绍

config:包含一些系统的配置文件,比如这个系统的启动端口,连接的数据库 target:程序的主体(jar文件) bat :两个bat文件都可以用来启动这个项目用的 其中start-service就是服务方式启动,缺点是双击后没有反应,优点是后台会一直启动。 start-terminal(推荐)是控制台启动,双击后弹出一个控制台黑框框,关掉控制台后系统就关掉了

2.启动系统

双击start-terminal.bat启动系统了,启动完成后,浏览器访问localhost

3.使用教程

下面介绍一些系统相关配置的注意事项 还有系统的一些便捷功能 避免生成的系统出现报错问题。

3.1界面

除了代码生成器这个模块,其他的功能没必要去管他 (这些就是历史原因了哈哈,本来想做一个网站的上线的…)

3.2 生成

在新增或者修改项目后,要记得保存,保存后下次可以复用

3.3 配置项

为了更好的发掘生成器的功能,我们可以灵活的运用配置项的功能。

C/C 属性配置示例:

C# / Javas程序配置示例:

通用配置
  • 命名 :系统、对象等命名时候,请避免使用特殊字符:# ¥ % & ^ ) - = : " ' } ]【】~!? . , < > / 、
  • 中文名 用于对象名或属性名的描述,这样生成的系统注释才会齐全。例:管理员
  • 是否查询 增删改查的查找功能中,如果查询设为【是】,则该属性会作为查询条件,例:可以通过姓名来查找学生
  • 是否统计 系统查询功能中,对于查出的数据会进行自动统计,例:每天的营业额设为统计,将自动对查询出来的数据求和
  • 是否平均 系统查询功能中,对于查出的数据会进行自动平均,例:学生身高设为平均,将自动显示平均身高
  • 更新页显示 修改/更新的时候,这个字段显示,例:我想让学生学号不可修改,我就可以设为否,默认是否
  • 可更新 是否可以更新这个字段,如果设为否,C#和Java 将会设为不可修改
  • 字段唯一 比如学号、身份证号码,他们是不会重复的字段,应该设为字段唯一。
  • 数据类型 C/C 的数据类型为char的时候,请在属性名后面加上长度,java和c#则不需要添加后缀[n],n表示字符数组长度
  • 最大长度 是C#和Java才有的配置,只有数据类型是String才生效。类似于c语言属性名的后缀,表示这个字段最长长度,一般用默认的255即可
  • 不为空 必填,例如:姓名为必填项
  • 配置下拉框 当下拉框的有值的时候,输入框会变成自动下拉框。例如:性别为 男、女
  • 默认值 新增的时候,默认会给这个属性赋值,在C语言和其他语言中有所不同,要注意。 例1:【字符串】例如我想名族默认是汉族:那么要填"汉族",要加双引号,类似于string family = “汉族”;填的是 = 后面的内容。 例2:【数字】数量默认是100:填100 例3:【时间】窗体生成分为Java和C#窗体,在java和C#中都有时间类型,Java的默认时间是 new Date(),而C#的为 DateTime.Now.ToString() ,这时为了统一配置,我用通配符来代替他们。例如我要设默认时间为当前时间,则填{time.now}(这是我自己制定的规则),生成的时候,他们会判断这是java、C#项目来自动设置默认值。
  • 外键 这一个内容要单独理解,配置简单,但是功能比较多,拿下图的学生成绩管理系统来说: 前提是我们已经添加了学生:Student对象和课程:Course对象,现在添加这个成绩对象 1、 看下图,课程和学生对应的外键已经填上了内容,这个意思指的是,学生成绩管理系统必须先添加学生和课程,才能添加成绩,没有学生和课程,哪来的成绩对吧? 2、 自动设置权限,这个学生,如果【是登陆用户】,那么学生登陆后,是只能查看自己的成绩的,这个用处很多,很重要。例如:借阅系统中,我们希望读者只能看到自己的借阅记录。 3、 便利的查询,在C#和Java中的查询框是可以设置为下拉框的,以下例子中,因为课程和学生都是外键而且他们是查询条件,所以生成的成绩管理系统,在查成绩的时候,可以通过下拉框来选择查询某个学生、课程的成绩。

部分代码

代码语言:javascript复制
public class MainView extends JFrame {
    JPanel northPanel = new JPanel(new FlowLayout(FlowLayout.LEFT));
    JButton addBtn = new JButton("增加");
    JButton updateBtn = new JButton("修改");
    JButton delBtn = new JButton("删除");
    JTextField searchTxt = new JTextField(15);
    JButton searchBtn = new JButton("查询");
JPanel southPanel = new JPanel(new FlowLayout(FlowLayout.LEFT));
JButton preBtn = new JButton("上一页");
JButton nextBtn = new JButton("下一页");

MainViewTable mainViewTable = new MainViewTable();
private int pageNo = 1;
private int pageSize = 10;

MainViewHandler mainViewHandler;

public MainView() {
    super("主界面-Java学生成绩管理");
    Container contentPane = getContentPane();
    Rectangle bounds = DimensionUtil.getBounds();
    pageSize = Math.floorDiv(bounds.height, 35);

    mainViewHandler = new MainViewHandler(this);
    // 放置北边的组件
    layoutNorth(contentPane);

    // 设置中间的jtable
    layoutCenter(contentPane);

    // 放置南边的组件
    layoutSouth(contentPane);
    // 自定义图标
    URL imgUrl = MainView.class.getClassLoader().getResource("learnIcon.jpg");
    setIconImage(new ImageIcon(imgUrl).getImage());

    // 根据屏幕大小设置主界面大小
    setBounds(bounds);
    // 设置窗体完全充满整个屏幕的可见大小
    setExtendedState(JFrame.MAXIMIZED_BOTH);
    setLocationRelativeTo(null);
    setDefaultCloseOperation(EXIT_ON_CLOSE);
    setResizable(true);
    setVisible(true);
}

private void layoutCenter(Container contentPane) {
    TableDTO dto = getTableDTO();
    MainViewTableModel mainViewTableModel = MainViewTableModel.assembleModel(dto.getData());
    // 把jtable和model关联
    mainViewTable.setModel(mainViewTableModel);
    mainViewTable.renderRule();
    JScrollPane jScrollPane = new JScrollPane(mainViewTable);
    contentPane.add(jScrollPane, BorderLayout.CENTER);
    showPreNext(dto.getTotalCount());
}

private TableDTO getTableDTO() {
    StudentService studentService = new StudentServiceImpl();
    StudentRequest request = new StudentRequest();
    request.setPageNo(pageNo);
    request.setPageSize(pageSize);
    request.setSearchKey(searchTxt.getText().trim());
    TableDTO tableDTO = studentService.retrieveStudents(request);
    return tableDTO;
}

private void layoutSouth(Container contentPane) {
    preBtn.addActionListener(mainViewHandler);
    nextBtn.addActionListener(mainViewHandler);
    southPanel.add(preBtn);
    southPanel.add(nextBtn);
    contentPane.add(southPanel, BorderLayout.SOUTH);
}

/*
设置上一页下一页是否可见
 */
private void showPreNext(int totalCount) {
    if (pageNo == 1) {
        preBtn.setVisible(false);
    } else {
        preBtn.setVisible(true);
    }
    int pageCount = 0;
    if (totalCount % pageSize == 0) {
        pageCount = totalCount / pageSize;
    } else {
        pageCount = totalCount / pageSize   1;
    }
    if (pageNo > pageCount) {
        pageNo = pageCount;
    } else if (pageNo < 1) {
        pageNo = 1;
    }
    if (pageNo == pageCount) {
        nextBtn.setVisible(false);
    } else {
        nextBtn.setVisible(true);
    }
}

private void layoutNorth(Container contentPane) {
    // 增加事件监听
    addBtn.addActionListener(mainViewHandler);
    updateBtn.addActionListener(mainViewHandler);
    delBtn.addActionListener(mainViewHandler);
    searchBtn.addActionListener(mainViewHandler);
    northPanel.add(addBtn);
    northPanel.add(updateBtn);
    northPanel.add(delBtn);
    northPanel.add(searchTxt);
    northPanel.add(searchBtn);
    contentPane.add(northPanel, BorderLayout.NORTH);
}

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

public void setPageNo(int pageNo) {
    this.pageNo = pageNo;
}

public int getPageNo() {
    return pageNo;
}

public void reloadTable() {
    TableDTO dto = getTableDTO();
    MainViewTableModel.updateModel(dto.getData());
    mainViewTable.renderRule();
    showPreNext(dto.getTotalCount());
}

public long[] getSelectedStudentIds() {
    int[] selectedRows = mainViewTable.getSelectedRows();
    long[] ids = new long[selectedRows.length];
    for (int i = 0; i < selectedRows.length; i  ) {
        int rowIndex = selectedRows[i];
        Object idObj = mainViewTable.getValueAt(rowIndex, 0);
        ids[i] = Long.parseLong(idObj.toString());
    }
    return ids;
}

public MainViewTable getMainViewTable() {
    return mainViewTable;
}
  }

效果

视频演示

接私活之课程设计学生成绩管理系统

https://www.bilibili.com/video/BV1mR4y1t7Ck?p=1&vd_source=97b717a7cd1b9ea962b07d744ed4fa26

0 人点赞