实验15:20211127 Java大数据1+X 中级实操考试(id:2660)

一、项目背景说明

学生成绩管理系统是中小学校等单位使用的一套系统,本项目使用控制台来模拟其部分功能。

  • 在学生成绩管理系统中涉及到的实体类有:学生类 Student、课程类 Course、成绩类 Score。
  • 对应的数据表有:学生表 student、课程表 course、成绩表 score。
  • 功能主要涉及到:学生信息管理、课程信息管理、成绩的录入与查询等功能。

二、表结构

  • student 表
    该表的含义是 学生,共有 4 个字段,详情如下:
表字段 数据库数据类型 含义 备注
name VARCHAR 学生姓名 主键
pwd VARCHAR 学生密码
age INT 学生年龄
grade INT 学生年级
rate INT 学生综合评级
  • course 表
    该表的含义是 课程,共有 3 个字段,详情如下:
表字段 数据库数据类型 备注 备注
name VARCHAR 课程名称 主键
teacher VARCHAR 授课老师
difficulty VARCHAR 课程难度
  • score 表
    该表的含义是 成绩,共有 3 个字段,详情如下:
表字段 数据库数据类型 含义 备注
sname VARCHAR 学生姓名 外键->学生表(name)
cname VARCHAR 课程名称 外键->课程表(name)
score INT 课程分数

三、步骤

【5 分】步骤 1:项目准备

复制粘贴、略。

【5 分】步骤 2:完成实体类 Student

题目:

首先我们要设计一系列的实体类,它们是 org.lanqiao.bean.Student、org.lanqiao.bean.Course、org.lanqiao.bean.Score, 现在 Student 类需要你来完善。

org.lanqiao.bean.Student是一个实体类,有五个属性,与数据库表 student 及其字段一一对应,对应关系如下。

【数据库表 student 的字段及其与实体类 Student 的属性的对应关系】

序号 类属性 表字段 数据库数据类型 备注
1 name name VARCHAR 主键
2 pwd pwd VARCHAR
3 age age INT
4 grade grade INT
5 rate rate INT

请根据注释要求,补全空缺的代码。

public class Student {
    
    
    private String name;//学生姓名
    private String pwd;//学生密码
    private int age;//学生年龄
    private int grade;//学生年级
    private int rate;//学生综合评级

    //已经提供Student类的属性,补充完成该类的有参(五个参数)及无参构造方法

答案:

//已经提供Student类的属性,补充完成该类的有参(五个参数)及无参构造方法
public Student(){
    
    }

public Student(String name, String pwd, int age, int grade, int rate){
    
    
	this.setName(name);
	this.setPwd(pwd);
	this.setAge(age);
	this.setGrade(grade);
	this.setRate(rate);
}

【10 分】步骤 3:完成实体类 Course

题目:

现在来完善 Course 课程类。

org.lanqiao.bean.Course是一个实体类,有三个属性,与数据库表 course 及其字段一一对应,对应关系如下。

【数据库表 course 的字段及其与实体类 Course 的属性的对应关系】

序号 类属性 表字段 数据库数据类型 备注
1 name name VARCHAR 主键
2 teacher teacher VARCHAR
3 difficulty difficulty VARCHAR

请根据注释要求,补全空缺的代码。

package org.lanqiao.bean;

public class Course {
    
    
    //请修改该方法,并且在赋值时,课程难度只能为:高、中、低这三种之一
    public void setDifficulty(String difficulty) {
    
    
        this.difficulty = difficulty;
    }

}

答案:

public void setDifficulty(String difficulty) {
    
    
	if (difficulty.equals("高")||difficulty.equals("中")||difficulty.equals("低")) {
    
    
		this.difficulty = difficulty;
	}
}

【10 分】步骤 4:完成实体类 Score

现在来完善 Score 成绩类。

org.lanqiao.bean.Score是一个实体类,有三个属性,与数据库表 score 及其字段一一对应,对应关系如下。

【数据库表 score 的字段及其与实体类 Score 的属性的对应关系】

序号 类属性 表字段 数据库数据类型 备注
1 sname sname VARCHAR
2 cname cname VARCHAR
3 score score INT

请根据注释要求,补全空缺的代码。

package org.lanqiao.bean;

public class Score {
    
    
    //请修改该方法,以保证打印对象时输出格式如下:(sname=zs;cname=语文;score=80)
    @Override
    public String toString() {
    
    
        return null;
    }

}

答案:

@Override
public String toString() {
    
    
	return "(sname="+this.getSname()+";cname="+this.getCname()+";score="+this.getScore()+")";
}

【10 分】步骤 5:完成 StudentDaoImpl 的 add 方法

题目:

数据存入数据库之后,我们需要进行相关的 CRUD,进行数据的处理和展示,数据库中有关学生的操作我们封装到 org.lanqiao.daoimpl.StudentDaoImpl 里面,请帮忙完成。

请根据注释要求,补全 add 方法。

/**
 * 插入学生
 * @param s 学生对象
 * @return
 */
public int add(Student s) {
    
    
    // 请补全sql语句
    String sql = "###";
    return studentUtil.add(sql,s.getName(),s.getPwd(),s.getAge(),s.getGrade(),s.getRate());
}

答案:

public int add(Student s) {
    
    
        // 请补全sql语句
        String sql = "insert student (name, pwd, age, grade, rate) values (?,?,?,?,?)";
        return studentUtil.add(sql, s.getName(),s.getPwd(),s.getAge(),s.getGrade(),s.getRate());
}

【10 分】步骤 6:完成 StudentDaoImpl 的 queryNum 方法

题目:

数据存入数据库之后,我们需要进行相关的 CRUD,进行数据的处理和展示,数据库中有关学生的操作我们封装到 org.lanqiao.daoimpl.StudentDaoImpl 里面,请帮忙完成。

请根据注释要求,补全 queryNum 方法。

/**
 * 查询学生总人数
 * @return 返回总人数
 */
public int queryNum() {
    
    
    String sql = "select * from student";
    List<Student> list = studentUtil.getList(sql, Student.class);
    // 请修改以下代码,保证返回值为总人数,假设所有学生名字都不一样
    int num = 0;
    return num;
}

答案:

public int queryNum() {
    
    
        String sql = "select * from student";
        List<Student> list = studentUtil.getList(sql, Student.class);
        // 请修改以下代码,保证返回值为总人数,假设所有学生名字都不一样
        int num = list.size();
        return num;
}

【10 分】步骤 7:完成 StudentDaoImpl 的 queryMinAge 方法

题目:

数据存入数据库之后,我们需要进行相关的 CRUD,进行数据的处理和展示,数据库中有关学生的操作我们封装到 org.lanqiao.daoimpl.StudentDaoImpl 里面,请帮忙完成。

请根据注释要求,补全 queryMinAge 方法。

/**
 * 查询最小年龄的学生姓名
 * @return 返回学生姓名
 */
public String queryMinAge() {
    
    
    // 请补全sql语句
    String sql = "###";
    Student g = studentUtil.getOne(sql, Student.class);
    return g.getName();
}

答案:

public String queryMinAge() {
    
    
        // 请补全sql语句
        String sql = "select name from student where age = (select min(age) from student)";
        Student g = studentUtil.getOne(sql, Student.class);
        return g.getName();
}

【10 分】步骤 8:完成 CourseDaoImpl 的 queryCourse 方法

题目:

数据存入数据库之后,我们需要进行相关的 CRUD,进行数据的处理和展示,数据库中有关课程的操作我们封装到 org.lanqiao.daoimpl.CourseDaoImpl 里面,请帮忙完成。

请根据注释要求,补全 queryCourse 方法。

/**
 * 根据课程名称来查询课程
 * @return 返回课程对象
 */
public Course queryCourse(String name) {
    
    
    // 请补全sql语句
    String sql = "###";
    return courseUtil.getOne(sql, Course.class, name);
}
        

答案:

public Course queryCourse(String name) {
    
    
        // 请补全sql语句
        String sql = "select * from course where name=?";
        return courseUtil.getOne(sql, Course.class, name);
}

【10 分】步骤 9:完成 CourseDaoImpl 的 updateDifficultyByName 方法

题目:

数据存入数据库之后,我们需要进行相关的 CRUD,进行数据的处理和展示,数据库中有关课程的操作我们封装到 org.lanqiao.daoimpl.CourseDaoImpl 里面,请帮忙完成。

请根据注释要求,补全 updateDifficultyByName 方法。

/**
 * 根据课程名称来更新课程难度
 * @return 更新成功返回true,没有更新成功返回false
 */
public boolean updateDifficultyByName(String name,String difficulty){
    
    
    // 请补全sql语句
    String sql = "###";
    int a = courseUtil.update(sql, difficulty, name);
    if(a>0){
    
    
            return true;
    }else{
    
    
            return false;  
    }
}
       

答案:

public boolean updateDifficultyByName(String name,String difficulty){
    
    
        // 请补全sql语句
        String sql = "update course set difficulty=? where name=?";
        int a = courseUtil.update(sql, difficulty, name);
        if(a>0){
    
    
                return true;
        }else{
    
    
                return false;  
        }
}

【10 分】步骤 10:完成 ScoreDaoImpl 的 queryAvgMax 方法

题目:

数据存入数据库之后,我们需要进行相关的 CRUD,进行数据的处理和展示,数据库中有关成绩的操作我们封装到 org.lanqiao.daoimpl.ScoreDaoImpl 里面,请帮忙完成。

请根据注释要求,补全 queryAvgMax 方法。

/**
 * 查询平均成绩最高的学生姓名
 * @return 返回学生姓名
 */
public String queryAvgMax() {
    
    
    // 请补全sql语句
    String sql = "###";
    Score s = scoreUtil.getOne(sql, Score.class);
    return s.getSname();
}

答案:

public String queryAvgMax() {
    
    
        // 请补全sql语句
        String sql = "select sname from score group by sname order by avg(score) desc limit 1";
        Score s = scoreUtil.getOne(sql, Score.class);
        return s.getSname();
}

【10 分】步骤 11:完成 ScoreDaoImpl 的 queryName 方法

题目:

数据存入数据库之后,我们需要进行相关的 CRUD,进行数据的处理和展示,数据库中有关成绩的操作我们封装到 org.lanqiao.daoimpl.ScoreDaoImpl 里面,请帮忙完成。

请根据注释要求,补全 queryName 方法。

/**
 * 查询至少考了2门课程的学生姓名
 * @return 返回所有满足条件的学生姓名的集合
 */
public Set<String> queryName() {
    
    
    // 查询出满足条件的成绩集合
    String sql = "select * from score where sname in(select sname from score group by sname having count(*)>=2)";
    List<Score> li = scoreUtil.getList(sql, Score.class);
    Set<String> s = new HashSet<String>();
    // 把集合 li 中的每个成绩对象的名字取出来放进集合 s 中,并返回
    // 请补全以下代码
    
    
    return s;
}

答案:

public Set<String> queryName() {
    
    
        // 查询出满足条件的成绩集合
        String sql = "select * from score where sname in(select sname from score group by sname having count(*)>=2)";
        List<Score> li = scoreUtil.getList(sql, Score.class);
        Set<String> s = new HashSet<String>();
        // 把集合 li 中的每个成绩对象的名字取出来放进集合 s 中,并返回
        // 请补全以下代码
        for (Score score : li){
    
    
                s.add(score.getSname());
        }
        
        return s;
}

猜你喜欢

转载自blog.csdn.net/realoser/article/details/131077408
今日推荐