中南林业科技大学Java实验报告十二:数据库系统设计 - 从0到1搭建java可视化学生管理系统源代码(二)

简介: 中南林业科技大学Java实验报告十二:数据库系统设计 - 从0到1搭建java可视化学生管理系统源代码

12.2.2.6 src下创建javabean文件夹并在javabean下创建Student类

Student类:

package javabean;
/**
 * 学生类
 */
public class Student {
    /**
     * 学号
     */
    private Integer stuId;
    /**
     * 姓名
     */
    private String name;
    /**
     * 专业
     */
    private String major;
    /**
     * 班级
     */
    private Integer classNum;
    /**
     * 平均成绩
     */
    private Double avgScore;
    public Student() {
    }
    public Student(Integer stuId, String name, String major, Integer classNum, Double avgScore) {
        this.stuId = stuId;
        this.name = name;
        this.major = major;
        this.classNum = classNum;
        this.avgScore = avgScore;
    }
    public Integer getStuId() {
        return stuId;
    }
    public void setStuId(Integer stuId) {
        this.stuId = stuId;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getMajor() {
        return major;
    }
    public void setMajor(String major) {
        this.major = major;
    }
    public Integer getClassNum() {
        return classNum;
    }
    public void setClassNum(Integer classNum) {
        this.classNum = classNum;
    }
    public Double getAvgScore() {
        return avgScore;
    }
    public void setAvgScore(Double avgScore) {
        this.avgScore = avgScore;
    }
    @Override
    public String toString() {
        return "Student{" +
                "stuId=" + stuId +
                ", name='" + name + '\'' +
                ", major='" + major + '\'' +
                ", className='" + classNum + '\'' +
                ", avgScore=" + avgScore +
                '}';
    }
}

12.2.2.7 src下创建dao文件夹并创建类和文件夹

12.2.2.7.1 BasicDao类
package dao;
import utils.JDBCUtilsByDruid;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.List;
public class BasicDao<T> {
    private QueryRunner queryRunner = new QueryRunner();
    //dml操作
    public int update(String sql,Object...parameters){
        Connection connection = null;
        try {
            connection = JDBCUtilsByDruid.getConnection();
            return queryRunner.update(connection,sql,parameters);
        } catch (SQLException e) {
            throw new RuntimeException(e);
        } finally {
            JDBCUtilsByDruid.close(null,null,connection);
        }
    }
    //操作多行数据,即返回多个对象
    public List<T> queryMulti(String sql,Class<T> clazz,Object...parameters){
        Connection connection = null;
        try {
            connection = JDBCUtilsByDruid.getConnection();
            return queryRunner.query(connection,sql,new BeanListHandler<T>(clazz),parameters);
        } catch (SQLException e) {
            throw new RuntimeException(e);
        } finally {
            JDBCUtilsByDruid.close(null,null,connection);
        }
    }
    //返回一行数据
    public T querySingle(String sql,Class<T> clazz,Object...parameters){
        Connection connection = null;
        try {
            connection = JDBCUtilsByDruid.getConnection();
            return queryRunner.query(connection,sql,new BeanHandler<T>(clazz),parameters);
        } catch (SQLException e) {
            throw new RuntimeException(e);
        } finally {
            JDBCUtilsByDruid.close(null,null,connection);
        }
    }
    //返回单行单列的结果
    public Object queryScalar(String sql,Object...parameters){
        Connection connection = null;
        try {
            connection = JDBCUtilsByDruid.getConnection();
            return queryRunner.query(connection,sql,new ScalarHandler<>(),parameters);
        } catch (SQLException e) {
            throw new RuntimeException(e);
        } finally {
            JDBCUtilsByDruid.close(null,null,connection);
        }
    }
}
12.2.2.7.2 StudentDao接口
package dao;
import javabean.Student;
import java.util.List;
public interface StudentDao{
    /**
     * 查询信息,按照分数降序排列
     *
     * @return 全部学生信息
     */
    List<Student> queryByScoreDesc();
    /**
     * 添加学生信息
     *
     * @param name 姓名
     * @param stuId 学号
     * @param major 专业
     * @param classNum 班级编号
     * @param avgScore 平均成绩
     */
    void add(String name,Integer stuId,String major,Integer classNum,Double avgScore);
    /**
     * 通过学号查询学生信息
     *
     * @param id 学号
     * @return 学生信息
     */
    Student queryByStuId(Integer id);
    /**
     * 通过学号删除学生信息
     *
     * @param stuId 学号
     */
    void delByStuId(Integer stuId);
    /**
     * 修改学生信息
     *
     * @param name 姓名
     * @param stuId 学号
     * @param major 专业
     * @param classNum 班级编号
     * @param avgScore 平均成绩
     */
    void updateByStuId(String name,Integer stuId,String major,Integer classNum,Double avgScore);
}
12.2.2.7.3 dao下创建impl文件夹并在impl下创建StudentDaoImpl类

StudentDaoImpl类:

package dao.impl;
import dao.BasicDao;
import dao.StudentDao;
import javabean.Student;
import java.util.List;
/**
 * Dao层实现类
 */
public class StudentDaoImpl extends BasicDao<Student> implements StudentDao{
    @Override
    public List<Student> queryByScoreDesc() {
        String sql = "SELECT stu_id AS `stuId`,`name`,major,class_num AS `classNum`,avg_score AS `avgScore`\n" +
                "FROM score ORDER BY avg_score DESC";
        return queryMulti(sql, Student.class);
    }
    @Override
    public void add(String name, Integer stuId, String major, Integer classNum, Double avgScore) {
        String sql = "INSERT INTO score(stu_id,`name`,major,class_num,avg_score) VALUES\n" +
                "(?,?,?,?,?)";
        update(sql,stuId,name,major,classNum,avgScore);
    }
    @Override
    public Student queryByStuId(Integer id) {
        String sql = "SELECT stu_id AS `stuId`,`name`,major,class_num AS `classNum`,avg_score AS `avgScore`\n" +
                "FROM score WHERE stu_id = ?";
        return querySingle(sql,Student.class,id);
    }
    @Override
    public void updateByStuId(String name, Integer stuId, String major, Integer classNum, Double avgScore) {
        String sql = "update score\n" +
                "set `name`= ?\n" +
                ",major = ?\n" +
                ",class_num = ?\n" +
                ",avg_score = ?\n" +
                "WHERE stu_id = ?";
        update(sql,name,major,classNum,avgScore,stuId);
    }
    @Override
    public void delByStuId(Integer stuId) {
        String sql = "DELETE FROM score\n" +
                "WHERE stu_id = ?";
        update(sql, stuId);
    }
}

12.2.2.8 src下创建service文件夹并创建类和文件夹

12.2.2.8.1 StudentService接口
package service;
import javabean.Student;
import java.util.List;
public interface StudentService {
    /**
     * 查询学生信息,按照平均成绩降序排列
     *
     * @return 学生信息
     */
    List<Student> queryByScoreDesc();
    /**
     * 添加学生信息
     *
     * @param name 姓名
     * @param stuId 学号
     * @param major 专业
     * @param classNum 班级编号
     * @param avgScore 平均成绩
     */
    void add(String name, Integer stuId, String major, Integer classNum, Double avgScore);
    /**
     * 通过学号查询学生信息
     *
     * @param id 学号
     * @return 学生信息
     */
    Student queryByStuId(Integer id);
    /**
     * 修改学生信息
     *
     * @param name 姓名
     * @param stuId 学号
     * @param major 专业
     * @param classNum 班级编号
     * @param avgScore 平均成绩
     */
    void updateByStuId(String name,Integer stuId,String major,Integer classNum,Double avgScore);
    /**
     * 通过学号删除学生信息
     *
     * @param id 学号
     */
    void delByStuId(Integer id);
}
12.2.2.8.2 service下创建impl文件夹并在impl下创建StudentServiceImpl类

StudentServiceImpl类:

package service.impl;
import dao.impl.StudentDaoImpl;
import dao.StudentDao;
import javabean.Student;
import service.StudentService;
import java.util.List;
/**
 * Student服务层实现
 */
public class StudentServiceImpl implements StudentService {
    private StudentDao studentDao = new StudentDaoImpl();
    @Override
    public List<Student> queryByScoreDesc() {
        return studentDao.queryByScoreDesc();
    }
    @Override
    public void add(String name, Integer stuId, String major, Integer classNum, Double avgScore) {
        studentDao.add(name, stuId, major, classNum, avgScore);
    }
    @Override
    public Student queryByStuId(Integer id) {
        return studentDao.queryByStuId(id);
    }
    @Override
    public void updateByStuId(String name, Integer stuId, String major, Integer classNum, Double avgScore) {
        studentDao.updateByStuId(name, stuId, major, classNum, avgScore);
    }
    @Override
    public void delByStuId(Integer stuId) {
        studentDao.delByStuId(stuId);
    }
}

12.2.2.9 src下创建component文件夹并在component下创建类


相关文章
|
6月前
|
资源调度 安全 Java
Java 大数据在智能教育在线实验室设备管理与实验资源优化配置中的应用实践
本文探讨Java大数据技术在智能教育在线实验室设备管理与资源优化中的应用。通过统一接入异构设备、构建四层实时处理管道及安全防护双体系,显著提升设备利用率与实验效率。某“双一流”高校实践显示,设备利用率从41%升至89%,等待时间缩短78%。该方案降低管理成本,为教育数字化转型提供技术支持。
166 1
|
7月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
6月前
|
消息中间件 机器学习/深度学习 Java
java 最新技术驱动的智能教育在线实验室设备管理与实验资源优化实操指南
这是一份基于最新技术的智能教育在线实验室设备管理与实验资源优化的实操指南,涵盖系统搭建、核心功能实现及优化策略。采用Flink实时处理、Kafka消息队列、Elasticsearch搜索分析和Redis缓存等技术栈,结合强化学习动态优化资源调度。指南详细描述了开发环境准备、基础组件部署、数据采集与处理、模型训练、API服务集成及性能调优步骤,支持高并发设备接入与低延迟处理,满足教育机构数字化转型需求。代码已提供下载链接,助力快速构建智能化实验室管理系统。
177 44
|
8月前
|
NoSQL Java API
在Java环境下如何进行Redis数据库的操作
总的来说,使用Jedis在Java环境下进行Redis数据库的操作,是一种简单而高效的方法。只需要几行代码,就可以实现复杂的数据操作。同时,Jedis的API设计得非常直观,即使是初学者,也可以快速上手。
359 94
|
XML Java 数据库连接
性能提升秘籍:如何高效使用Java连接池管理数据库连接
在Java应用中,数据库连接管理至关重要。随着访问量增加,频繁创建和关闭连接会影响性能。为此,Java连接池技术应运而生,如HikariCP。本文通过代码示例介绍如何引入HikariCP依赖、配置连接池参数及使用连接池高效管理数据库连接,提升系统性能。
229 5
|
8月前
|
Java 关系型数据库 MySQL
Java汽车租赁系统源码(含数据库脚本)
Java汽车租赁系统源码(含数据库脚本)
177 4
|
10月前
|
人工智能 JavaScript 关系型数据库
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
381 14
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
|
9月前
|
前端开发 JavaScript Java
[Java计算机毕设]基于ssm的OA办公管理系统的设计与实现,附源码+数据库+论文+开题,包安装调试
OA办公管理系统是一款基于Java和SSM框架开发的B/S架构应用,适用于Windows系统。项目包含管理员、项目管理人员和普通用户三种角色,分别负责系统管理、请假审批、图书借阅等日常办公事务。系统使用Vue、HTML、JavaScript、CSS和LayUI构建前端,后端采用SSM框架,数据库为MySQL,共24张表。提供完整演示视频和详细文档截图,支持远程安装调试,确保顺利运行。
388 17
|
10月前
|
人工智能 JavaScript 安全
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
467 13
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
|
10月前
|
存储 缓存 Java
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
1172 3
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡

热门文章

最新文章