步骤一
安装要求复制粘贴即可
步骤二
package org.lanqiao.bean;
/**
* 学生类
*/
public class Student {
private String name;//学生姓名
private String pwd;//学生密码
//已经提供Student类的属性,补充完成该类的有参(两个参数)及无参构造方法
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPwd() {
return pwd;
}
public void setPwd(String pwd) {
this.pwd = pwd;
}
}
步骤三
public class DateUtil {
private static SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
/**
* 使用全局变量: sdf,将字符串转换为java.util.Date类型并返回
* 注意,不能声明任何形式的异常抛出,否则测试用例无法通过
* @param stringDate
* @return
*/
public static Date convertFromStringToDate(String stringDate) {
// 补全代码:
Date date = null;
try{
date = sdf.parse(stringDate);
}catch(Exception e){
e.printStackTrace();
}
return date;
}
步骤四
/**
* 使用全局变量: sdf,将日期转换成字符串
* @param date 需要被转换的日期
* @return 转换之后的字符串形式的日期
*/
public static String convertFromDateToString(Date date) {
// 补全或替换代码
return sdf.format(date);
}
}
步骤五
/**
* 依据书名查询书籍
* @param bname 书名
* @return 有的话返回书籍对象(唯一),没有的话返回null
*/
public Book findByName(String bname){
// 请补全sql语句
String sql = "select * from book where name=?";
Book b = ou.getOne(sql, Book.class, bname);
return b;
}
步骤六
/**
* 查询所有书籍中价钱最贵的书籍名称
* @return 返回书籍名称
*/
public String queryExpensiveBook(){
// 请补全sql语句
String sql = "select * from book where price=(select max(price) from book)";
Book b = ou.getOne(sql, Book.class);
return b.getName();
}
步骤七
public void changePwd(String name,String oldPwd,String newPwd){
// 1.先判断学生姓名和旧密码是否正确
// 请补全sql语句
String sql1 = "select * from student where name=? and pwd=?";
Student s = ou.getOne(sql1, Student.class, name, oldPwd);
步骤八
// 2.姓名和旧密码正确,则更新;姓名和旧密码不正确,则不更新
if(s!=null){
// 请补全sql语句
String sql2 = "update student set pwd=? where name=?";
ou.update(sql2, newPwd, name);
}
}
步骤九
// 往 sb 表中插入相关信息:学生姓名,书籍名称,借书时间。自增id和还书时间不用插入。
// 请补全sql语句
String sql1 = "insert into sb (sname,bname,begintime) values (?,?,?)";
ou.add(sql1,sb.getSname(),sb.getBname(),DateUtil.convertFromDateToString(sb.getBeginTime()));
// 更新 book 表中对应书籍的数量减1
// 请补全sql语句
String sql2 = "update book set num=num-1 where name=?";
ou.update(sql2, sb.getBname());
步骤十
public boolean giveBack(SB sb){
//1.首先查询某人是否在某个时间借阅了某书,但是还没有归还
// 请补全sql语句
String sql = "select * from sb where sname=? and bname=? and begintime=?";
String btime = DateUtil.convertFromDateToString(sb.getBeginTime());
SB f = ou.getOne(sql, SB.class, sb.getSname(),sb.getBname(), btime);
//2.借了则归还,并返回true;没有借则不用归还,并返回false
if(f!=null){
// 根据借书人、借书名称、借书时间来更新 sb 表中的还书时间为当前时间
// 请补全sql语句
String sql1 = "update sb set endtime=? where sname=? and bname=? and begintime=?";
ou.update(sql1, DateUtil.convertFromDateToString(new Date()),sb.getSname(),sb.getBname(),DateUtil.convertFromDateToString(sb.getBeginTime()));
// 更新 book 表中对应书籍的数量加1
// 请补全sql语句
String sql2 = "update book set num=num+1 where name=?";
ou.update(sql2, sb.getBname());
return true;
}else{
return false;
}
}