实验12:20220521 1+X 中级实操考试(id:3352)

用于学习整理,答案都是检测通过 

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

目录

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

 【10 分】步骤 2:完成实体类 Staff

 【10 分】步骤 3:完成 Staff 的 toString 方法

 【10 分】步骤 4:完成 Salary

 【10 分】步骤 5:完成 SSDaoImpl 的 queryStaff 方法

 【10 分】步骤 6:继续完善 SSDaoImpl 类

 【15 分】步骤 7:继续完善 SBDaoImpl 类

 【15 分】步骤 8:继续完善 SSDaoImpl 类

 【15 分】步骤 9:继续完善 SSDaoImpl 类


 【10 分】步骤 2:完成实体类 Staff

package org.lanqiao.bean;

public class Staff {
    //补充完成该类的含参构造方法
    public Staff(String id, String name, int age, String sex, int sage) {
        
    }

}

答案

	//补充完成该类的含参构造方法
	public Staff(String id, String name, int age, String sex, int sage) {
		this.id = id;
		this.name = name;
		this.age = age;
		this.sex =sex;
		this.sage = sage;
		
	}

 【10 分】步骤 3:完成 Staff 的 toString 方法

    // 请修改该方法,以保证打印对象时输出格式如下:
    // {id:'001';name:'zs';age:20;sex:'男';sage:3}
    @Override
    public String toString() {
        return "";
    }

答案

	public String toString() {
		return "{id:\'" + id + "\';name:\'" + name + "\';age:" + age + ";sex:\'" + sex + "\';sage:" + sage + "}" ;
	}

需要注意的是字符串拼接中出现的单引号

 【10 分】步骤 4:完成 Salary

    // 缺失代码:请补全以下方法,要求工资数量的范围在:1000<=num<10000 之间
    // 当参数在规定范围外时,不做任何动作
    public void setNum(int num) {
        
        
    }

答案

	public void setNum(int num) {
		if(num >= 1000 && num < 10000){
			this.num = num;
		}

 【10 分】步骤 5:完成 SSDaoImpl 的 queryStaff 方法

    /**
     * 依据职工姓名查询职工
     * @param name 职工姓名
     * @return 有的话返回职工对象,没有的话返回null
     */
    public Staff queryStaff(String name){
        // 请补全sql语句
        String sql = "###";
        Staff b = staffUtil.getOne(sql, Staff.class, name);
        return b;
    }

答案

                // 请补全sql语句
                String sql = "select * from staff where name = ?";

 【10 分】步骤 6:继续完善 SSDaoImpl 类

/**
     * 查询某位职工某年某月的工资
     * @param name 职工姓名
     * @param year 年份
     * @param month 月份
     * @return 返回工资
     */
    public int querySalary(String name,int year,int month){
        // 请补全sql语句
        String sql = "###";
        Salary sa = salaryUtil.getOne(sql, Salary.class, name, year, month);
        return sa.getNum();
    }
        

用到关联表查询

                // // 请补全sql语句
                String sql = "select SA.num from staff ST,salary SA where ST.id=SA.id and ST.name = ? and SA.year = ? and SA.month = ?";

当然也可以用到子查询


String sql = "select * from salary where id = (select id from staff where name = ?) and year=? and month = ?";
 

 【15 分】步骤 7:继续完善 SBDaoImpl 类

    /**
     * 查询工龄最高的职工
     * @return 返回工龄最高的职工对象
     */
    public Staff queryMaxSage(){
        // 请补全sql语句
        String sql = "###";
        Staff st = staffUtil.getOne(sql, Staff.class);
        return st;
    }

答案

                // 请补全sql语句
                String sql = "select * from staff  order by sage DESC limit 1 ";

 【15 分】步骤 8:继续完善 SSDaoImpl 类

    /**
     * 查询某位职工的最高工资
     * @param name 职工姓名
     * @return 返回该职工的最高工资
     */
    public int queryMaxSalary(String name){
        // 请补全sql语句
        String sql = "###";
        Salary s = salaryUtil.getOne(sql, Salary.class, name);
        return s.getNum();
    }
        

答案

	public int queryMaxSalary(String name){
                String sql = "select sa.* from staff st,salary sa where st.id=sa.id and st.name=? order by num desc limit 1";
                Salary s = salaryUtil.getOne(sql, Salary.class, name);
                return s.getNum();        
        }

当然也可以使用子查询

                // 请补全sql语句
                String sql = "select * from salary where id = (select id from staff where name = ? ) order by num  DESC limit 1";
                Salary s = salaryUtil.getOne(sql, Salary.class, name);
                return s.getNum();

 【15 分】步骤 9:继续完善 SSDaoImpl 类

    /**
     * 使所有职工的年龄加1
     */
    public void updateAge(){
        // 请补全sql语句
        String sql = "###";
        int i = staffUtil.update(sql);
    }

答案

               // 请补全sql语句
               String sql = "update staff set age = age+1";

你可能感兴趣的:(1+X,java,mysql)