赞
踩
学生成绩管理系统是中小学校等单位使用的一套系统,本项目使用控制台来模拟其部分功能。
表字段 | 数据库数据类型 | 含义 | 备注 |
---|---|---|---|
name | VARCHAR | 学生姓名 | 主键 |
pwd | VARCHAR | 学生密码 | |
age | INT | 学生年龄 | |
grade | INT | 学生年级 | |
rate | INT | 学生综合评级 |
表字段 | 数据库数据类型 | 备注 | 备注 |
---|---|---|---|
name | VARCHAR | 课程名称 | 主键 |
teacher | VARCHAR | 授课老师 | |
difficulty | VARCHAR | 课程难度 |
表字段 | 数据库数据类型 | 含义 | 备注 |
---|---|---|---|
sname | VARCHAR | 学生姓名 | 外键->学生表(name) |
cname | VARCHAR | 课程名称 | 外键->课程表(name) |
score | INT | 课程分数 |
复制粘贴、略。
题目:
首先我们要设计一系列的实体类,它们是 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);
}
题目:
现在来完善 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;
}
}
现在来完善 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()+")";
}
题目:
数据存入数据库之后,我们需要进行相关的 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());
}
题目:
数据存入数据库之后,我们需要进行相关的 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;
}
题目:
数据存入数据库之后,我们需要进行相关的 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();
}
题目:
数据存入数据库之后,我们需要进行相关的 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);
}
题目:
数据存入数据库之后,我们需要进行相关的 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;
}
}
题目:
数据存入数据库之后,我们需要进行相关的 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();
}
题目:
数据存入数据库之后,我们需要进行相关的 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;
}
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。