中南林业科技大学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下创建类


相关文章
|
Cloud Native 关系型数据库 分布式数据库
阿里云PolarDB与沃趣科技携手打造一体化数据库解决方案,助推国产数据库生态发展
阿里云瑶池数据库与沃趣科技将继续深化合作,共同推动国产数据库技术的持续创新与广泛应用,为行业生态的繁荣注入更强劲的技术动力。
阿里云PolarDB与沃趣科技携手打造一体化数据库解决方案,助推国产数据库生态发展
|
9月前
|
存储 供应链 数据可视化
Java 大视界 -- 基于 Java 的大数据可视化在企业供应链风险预警与决策支持中的应用(204)
本篇文章探讨了基于 Java 的大数据可视化技术在企业供应链风险预警与决策支持中的深度应用。文章系统介绍了从数据采集、存储、处理到可视化呈现的完整技术方案,结合供应链风险预警与决策支持的实际案例,展示了 Java 大数据技术如何助力企业实现高效、智能的供应链管理。
|
10月前
|
存储 数据采集 数据可视化
Java 大视界 -- 基于 Java 的大数据可视化在城市交通拥堵溯源与治理策略展示中的应用(191)
本项目探索了基于Java的大数据可视化技术在城市交通拥堵溯源与治理策略中的应用。通过整合多源交通数据,利用Java生态中的大数据处理与可视化工具,构建了交通拥堵分析模型,并实现了拥堵成因的直观展示与治理效果的可视化评估。该方案为城市交通管理提供了科学、高效的决策支持,助力智慧城市建设。
|
11月前
|
存储 数据采集 数据可视化
Java 大视界 -- 基于 Java 的大数据可视化在城市地下管网管理与风险预警中的应用(275)
本文系统阐述 Java 与大数据可视化技术在城市地下管网管理中的应用,涵盖数据采集、三维建模、风险预警及性能优化,结合真实案例提供可落地的技术方案。
|
数据可视化 Java 大数据
Java 大视界 -- 基于 Java 的大数据可视化在城市规划决策支持中的交互设计与应用案例(164)
本文围绕基于 Java 的大数据可视化在城市规划决策支持中的应用展开,分析决策支持现状与挑战,阐述技术应用方法,结合实际案例和代码,提供实操性强的技术方案。
|
Cloud Native 关系型数据库 MySQL
华鼎冷链科技 × 阿里云瑶池数据库,打造全链路协同的智慧冷链新标杆
从 PolarDB 的高性能数据库服务到 AnalyticDB 的强大数据分析,阿里云提供的丰富产品矩阵为华鼎冷链科技构建了全面的解决方案,推动华鼎冷链科技从成本中心向效率中心转型。
|
存储 SQL 运维
当「内容科技企业」遇上多模数据库:新榜采用Lindorm打造全域数据“超级底盘”
新榜业务以数据服务提升内容产业信息流通效率,其数据处理需求聚焦于跨平台实时数据融合处理、实时分析检索、批量更新效率三大维度。Lindorm通过多模超融合架构,提供检索分析一体化、多引擎数据共享,分布式弹性扩展等能力,成为支撑新榜内容服务的核心引擎,助力客户在内容生态竞争中持续领跑。
|
存储 NoSQL 关系型数据库
阿里云数据库MongoDB版助力信也科技 打造互联网金融企业样板
我们的风控系统引入阿里云数据库MongoDB版后,解决了特征类字段灵活加减的问题,大大提高了开发效率,极大的提升了业务用户体验,获得了非常好的效果
阿里云数据库MongoDB版助力信也科技 打造互联网金融企业样板
|
Cloud Native 关系型数据库 分布式数据库
阿里云牵手海亮科技,共建“教育科技数据库创新应用中心”
近日,阿里云与世界500强旗下、国内领先的教育服务提供商海亮科技集团(以下简称“海亮科技”)达成合作,联合成立“教育科技数据库创新应用中心”。双方将充分整合优势资源,共同推进教育科技领域的数据库技术研究和国产数据库的应用与发展。
385 8
|
Cloud Native 关系型数据库 Serverless
阿里云数据库获中国计算机学会“科技进步一等奖”!
阿里云数据库获中国计算机学会“科技进步一等奖”!
354 0