实验10:20211219 1+X 中级实操考试(id:2846)

用于笔记复习--实验10与实验9题目与答案相同(对实验9进行复习)

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

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

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

    //补充完成该类的含参构造方法
    public Student(String name, String pwd, int age, int grade, int rate) {
        
        
    }

 答案

	//补充完成该类的含参构造方法
	public Student(String name, String pwd, int age, int grade, int rate) {
		this.name = name;
		this.pwd = pwd;
		this.age = age;
		this.grade = grade;
		this.rate = rate;
	}

 实验10和实验9在步骤二的区别就是不用去手写无参和有参构造函数,补全有参构造就可以了

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

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

package org.lanqiao.bean;

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

}

答案

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

字符串拼接的时候需要注意样例给出的冒号和分号

 【10 分】步骤 5:完成 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 into student values(?,?,?,?,?)";
                return studentUtil.add(sql, s.getName(),s.getPwd(),s.getAge(),s.getGrade(),s.getRate());
        }

SQL添加数据的语法

①:给指定数列添加数据

insert into 表名(列名1,列名2,...)values(值1,值2,...);

②:给指定列批量添加数据

insert into 表名(列名1,列名2,...)values(值1,值2,...),(值1,值2,...),(值1,值2,...);

③:给全部列添加数据

insert into 表名 values (值1,值2,...,值n);

④:给全部列批次添加数据

insert into 表名 values (值1,值2,...),(值1,值2,...);

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

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

答案

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

只需要把list集合的长度赋值给num返回

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

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

答案

	public String queryMaxAge() {
                // 请补全sql语句
                String sql = "select * from student order by age DESC limit 1";
                Student g = studentUtil.getOne(sql, Student.class);
                return g.getName();
        }

排列查询:order by   

排序降序:DESC

分页查询:limit

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

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

答案

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

条件查询:where

查询表的全部字段:select * from course

【10 分】步骤9:完 成 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;  
                }
        }

修改表数据: update 表名 set 列名1 = 值1, 列名2 = 值2, [where 条件]

 【10 分】步骤 10:完成 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,avg(score) from score group by sname order by avg(score) DESC limit 1";
                Score s = scoreUtil.getOne(sql, Score.class);
                return s.getSname();
        }

分组查询: group by 

排列查询:order by  

对学生的平均分成绩进行分组汇总

select的查询字段注意 , 分隔

 【10 分】步骤 11:完成 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;
}

答案

                // 把集合 li 中的每个成绩对象的名字取出来放进集合 s 中,并返回
                // 请补全以下代码
                for(int i = 0; i < li.size(); i++){
                        s.add(li.get(i).getSname());
                }

                return s;

用循环把li里面的姓名添加给s集合

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

长风沛雨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值