当前位置:   article > 正文

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

20211127 1+x 中级实操考试(id:2660)

一、项目背景说明

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

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

二、表结构

  • student 表
    该表的含义是 学生,共有 4 个字段,详情如下:
表字段数据库数据类型含义备注
nameVARCHAR学生姓名主键
pwdVARCHAR学生密码
ageINT学生年龄
gradeINT学生年级
rateINT学生综合评级
  • course 表
    该表的含义是 课程,共有 3 个字段,详情如下:
表字段数据库数据类型备注备注
nameVARCHAR课程名称主键
teacherVARCHAR授课老师
difficultyVARCHAR课程难度
  • score 表
    该表的含义是 成绩,共有 3 个字段,详情如下:
表字段数据库数据类型含义备注
snameVARCHAR学生姓名外键->学生表(name)
cnameVARCHAR课程名称外键->课程表(name)
scoreINT课程分数

三、步骤

【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 的属性的对应关系】

序号类属性表字段数据库数据类型备注
1namenameVARCHAR主键
2pwdpwdVARCHAR
3ageageINT
4gradegradeINT
5raterateINT

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

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

    //已经提供Student类的属性,补充完成该类的有参(五个参数)及无参构造方法
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

答案:

//已经提供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);
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

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

题目:

现在来完善 Course 课程类。

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

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

序号类属性表字段数据库数据类型备注
1namenameVARCHAR主键
2teacherteacherVARCHAR
3difficultydifficultyVARCHAR

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

package org.lanqiao.bean;

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

}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

答案:

public void setDifficulty(String difficulty) {
	if (difficulty.equals("高")||difficulty.equals("中")||difficulty.equals("低")) {
		this.difficulty = difficulty;
	}
}
  • 1
  • 2
  • 3
  • 4
  • 5

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

现在来完善 Score 成绩类。

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

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

序号类属性表字段数据库数据类型备注
1snamesnameVARCHAR
2cnamecnameVARCHAR
3scorescoreINT

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

package org.lanqiao.bean;

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

}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

答案:

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

【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());
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

答案:

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());
}
  • 1
  • 2
  • 3
  • 4
  • 5

【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;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

答案:

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

【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();
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

答案:

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();
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

【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);
}
        
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

答案:

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

【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;  
    }
}
       
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

答案:

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;  
        }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

【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();
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

答案:

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();
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

【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;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

答案:

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;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/正经夜光杯/article/detail/804024
推荐阅读
相关标签
  

闽ICP备14008679号