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


	//已经提供Student类的属性,补充完成该类的有参(五个参数)及无参构造方法
	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;
	}

//请修改该方法,并且在赋值时,课程难度只能为:高、中、低这三种之一,其余值不做任何处理。
	public void setDifficulty(String difficulty) {
		if(difficulty.equals("高")||difficulty.equals("中")||difficulty.equals("低")){
			this.difficulty = difficulty;
		}
	}

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

import java.util.List;

import org.lanqiao.bean.Student;
import org.lanqiao.dao.StudentDao;
import org.lanqiao.db.ObjectUtil;

/**
 * 接口实现类
 */
public class StudentDaoImpl implements StudentDao{
        /*
         * ObjectUtil工具类提供的方法能实现对数据库的CRUD操作
         * */
        ObjectUtil<Student> studentUtil = new ObjectUtil<Student>();

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

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

        /**
	 * 插入学生
	 * @param s 学生对象
	 * @return
	 */
	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());
        }

        /**
	 * 依据学生姓名来删除学生
	 * @param name 学生姓名
	 * @return 存在名字则删除,并返回true;不存在则不删除,并返回false
	 */
	public boolean deleteStudent(String name) {
                String sql = "delete from student where name=?";
                int a = studentUtil.delete(sql, name);
                if(a>0){
                          return true;
                }else{
                          return false;  
                }
        }
}
package org.lanqiao.daoimpl;

import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;

import org.lanqiao.bean.Score;
import org.lanqiao.dao.ScoreDao;
import org.lanqiao.db.ObjectUtil;

/**
 * 接口实现类
 */
public class ScoreDaoImpl implements ScoreDao{
        /*
         * ObjectUtil工具类提供的方法能实现对数据库的CRUD操作
         * */
        ObjectUtil<Score> scoreUtil = new ObjectUtil<Score>();

        /**
	 * 查询至少考了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 中,并返回
                // 请补全以下代码
                for (Score score : li) {
                        s.add(score.getSname());
                }
                return s;
        }


        /**
	 * 查询平均成绩最高的学生姓名
	 * @return 返回学生姓名
	 */
	public String queryAvgMax() {
                // 请补全sql语句
                String sql = "select * from score where sname=(select sname from score group by sname order by avg(score) desc limit 1)";
                Score s = scoreUtil.getOne(sql, Score.class);
                return s.getSname();
        }

        /**
	 * 插入成绩
	 * @param score 成绩对象
	 * @return
	 */
	public int add(Score score) {
                String sql = "insert into score values(?,?,?)";
                return scoreUtil.add(sql, score.getSname(),score.getCname(),score.getScore());
        }

        /**
	 * 依据学生姓名和课程名称来删除成绩
	 * @param sname 学生姓名
	 * @param cname 课程名称
	 * @return 存在则删除,并返回true;不存在则不删除,并返回false
	 */
	public boolean deleteScore(String sname,String cname) {
                String sql = "delete from score where sname=? and cname=?";
                int a = scoreUtil.delete(sql, sname, cname);
                if(a>0){
                          return true;
                }else{
                          return false;  
                }
        }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

爱吃java的羊儿

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

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

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

打赏作者

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

抵扣说明:

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

余额充值