前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Java私活200元,完成JavaSwing学生成绩管理系统(三)

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

作者头像
Maynor
发布2022-09-02 18:11:07
6510
发布2022-09-02 18:11:07
举报

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

需求

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

origin_img_v2_fba4286e-e8cb-418b-9d1d-38410b39e06g
origin_img_v2_fba4286e-e8cb-418b-9d1d-38410b39e06g

具体需求如下:

用户需求

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

功能需求

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

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

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

需求分析

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

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

origin_img_v2_0543a598-394f-4699-a030-41e9dfb88a7g
origin_img_v2_0543a598-394f-4699-a030-41e9dfb88a7g

代码生成器实现原理

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;
}
  }

效果

image-20220701161539238
image-20220701161539238
image-20220701161559377
image-20220701161559377
image-20220701161618017
image-20220701161618017

视频演示

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

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

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-07-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Java私活200元,完成JavaSwing学生成绩管理系统(三)
  • 需求
    • 具体需求如下:
    • 需求分析
    • 代码生成器实现原理
      • 1.文件目录介绍
      • 2.启动系统
        • 3.使用教程
          • 3.1界面
            • 3.2 生成
              • 3.3 配置项
                • 通用配置
            • 部分代码
            • 效果
            • 视频演示
            相关产品与服务
            数据库
            云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档