您现在的位置是:首页 > 正文

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

2024-02-01 04:22:34阅读 2

一、项目背景说明

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

  • 在学生成绩管理系统中涉及到的实体类有:学生类 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;
}

网站文章

  • pytorch里的nn.Embedding是什么东西?

    pytorch里的nn.Embedding是什么东西?

    2024-02-01 04:22:18
  • [NepCTF2022] 复现

    [NepCTF2022] 复现

    www.zip源码泄露,啥也不懂没注意正确的入口在哪里,一直把注意力放在web.php上面。附件下载后是个osz后缀,当时用010看是压缩包文件头,就改后缀了。当时写的过程,确实9.12.2的版本也是...

    2024-02-01 04:22:11
  • aes key长度_AES 自动打分 Automated Essay Scoring

    aes key长度_AES 自动打分 Automated Essay Scoring

    文章自动打分简称 AES (Automated Essay Scoring),AES 系统利用 NLP 技术自动对文章进行打分,可以减轻阅卷人员的负担。目前有不少大型的考试都采用了 AES 算法进行作...

    2024-02-01 04:21:42
  • 图解TCP/udp及socket

    图解TCP/udp及socket

    TCP/IP(Transmission Control Protocol/Internet Protocol)即传输控制协议/网间协议,是一个工业标准的协议集,它是为广域网(WANs)设计的。 UDP(User Data Protocol,用户数据报协议)是与TCP相对应的协议。它是属于TCP/IP协议族中的一种。 协议的关系图

    2024-02-01 04:21:36
  • 英文地址怎么写?!!

    北京市东花市北里20号楼6单元501室Room 501 ,Unit 6,Building 20 North Donghuashi Residential Chongwen District BeiJi...

    2024-02-01 04:21:29
  • Redis基本概念及发展历史

    redis NOSQL(not only SQL)数据库 Jedis是Redis在Java中的常用客户端(依赖包),提供多种方法操作redis 数据类型 类型 结构 string key(string...

    2024-02-01 04:21:00
  • java将网络资源url转换成File文件

    【代码】java将网络资源url转换成File文件。

    2024-02-01 04:20:54
  • 小白学习spring第二天

    小白学习spring第二天

    spring

    2024-02-01 04:20:46
  • 查看so文件的细节。

    一、readelf命令:https://man.linuxde.net/readelf二、strings命令:https://blog.csdn.net/xinqi53/article/details/9126475

    2024-02-01 04:20:12
  • HashMap 对于key是null值的存储

    https://www.jianshu.com/p/dfffb4b06d6e https://blog.csdn.net/fenglongmiao/article/details/79656198 HashMap 允许插入键为 null 的键值对。但是因为无法调用 null 的 hashCode() 方法,也就无法确定该键值对的桶下标,只能通过强制指定一个桶下标来存放。HashMap 使...

    2024-02-01 04:20:04