用于学习整理,答案都是检测通过
目录
【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 类
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;
}
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 + "}" ;
}
需要注意的是字符串拼接中出现的单引号
Salary
// 缺失代码:请补全以下方法,要求工资数量的范围在:1000<=num<10000 之间
// 当参数在规定范围外时,不做任何动作
public void setNum(int num) {
}
答案
public void setNum(int num) {
if(num >= 1000 && num < 10000){
this.num = num;
}
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 = ?";
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 = ?";
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 ";
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();
SSDaoImpl
类 /**
* 使所有职工的年龄加1
*/
public void updateAge(){
// 请补全sql语句
String sql = "###";
int i = staffUtil.update(sql);
}
答案
// 请补全sql语句
String sql = "update staff set age = age+1";