(用于学习笔记)
1+X的中级实操题库中,实验7与实验11题目要求均相同,只有两个步骤有区别
目录
【10 分】步骤 3:完成工具类 DateUtil的convertFromStringToDate方法
【10 分】步骤 4:完成工具类 DateUtil的convertFromDateToString方法
实验一中的数据
【10 分】步骤 5:完成 SBDaoImpl 的 findByName 方法
【5 分】步骤 1:项目准备
复制粘贴即可,如果在步骤中进行了该操作
后续操作需要退出数据库(exit)才能操作后面的步骤指令
【5 分】步骤 2:完成实体类 Student
package org.lanqiao.bean;
public class Student {
private String name;
private String pwd;
//已经提供Student类的属性,补充完成该类的有参(两个参数)及无参构造方法
}
需求:写出Student类的有参与无参方法
//已经提供Student类的属性,补充完成该类的有参(两个参数)及无参构造方法
public Student(){
}
public Student(String name, String pwd){
this.name = name;
this.pwd = pwd;
}
【10 分】步骤 3:完成工具类 DateUtil
的convertFromStringToDate
方法
/**
* 使用全局变量: sdf,将字符串转换为java.util.Date类型并返回
* @param stringDate
* 注意,不能声明任何形式的异常抛出,否则测试用例无法通过
* @return
*/
public static Date convertFromStringToDate(String stringDate) {
// 补全代码:
Date date = null;
return date;
}
答案
public static Date convertFromStringToDate(String stringDate) {
// 补全代码:
Date date = null;
try{
date = sdf.parse(stringDate);
}catch(Exception e){
}
return date;
}
包装类提供了一个静态方法parseXXX(String str) 可以将给定的字符串转换为对应的基本类型。
【10 分】步骤 4:完成工具类 DateUtil
的convertFromDateToString
方法
/**
* 使用全局变量: sdf,将日期转换成字符串
* @param date 需要被转换的日期
* @return 转换之后的字符串形式的日期
*/
public static String convertFromDateToString(Date date) {
// 补全或替换代码
return null;
}
答案
public static String convertFromDateToString(Date date) {
// 补全或替换代码
return sdf.format(date);
}
了解数据
后面的操作都是SQL语法,这是实验一中的数据
student
表
该表的含义是 学生,共有 2 个字段,详情如下:
表字段 | 数据库数据类型 | 含义 | 备注 |
---|---|---|---|
name | VARCHAR | 学生姓名 | 主键 |
pwd | VARCHAR | 学生密码 |
book
表
该表的含义是 书籍,共有 4 个字段,详情如下:
表字段 | 数据库数据类型 | 备注 | 备注 |
---|---|---|---|
name | VARCHAR | 书籍名称 | 主键 |
author | VARCHAR | 书籍作者 | |
price | INT | 书籍价钱 | |
num | INT | 书籍数量 |
sb
表
该表的含义是 借书还书,共有 5 个字段,详情如下:
表字段 | 数据库数据类型 | 含义 | 备注 |
---|---|---|---|
id | INT | 序列号 | 自增长 |
sname | VARCHAR | 学生姓名 | 外键->学生表(name) |
bname | VARCHAR | 书籍名称 | 外键->书籍表(name) |
begintime | DATETIME | 借阅时间 | |
endtime | DATETIME | 归还时间 |
【10 分】步骤 5:完成 SBDaoImpl
的 findByName
方法
/**
* 依据书名查询书籍
* @param bname 书名
* @return 有的话返回书籍对象(唯一),没有的话返回null
*/
public Book findByName(String bname){
// 请补全sql语句
String sql = "###";
Book b = ou.getOne(sql, Book.class, bname);
return b;
}
答案
public Book findByName(String bname){
// 请补全sql语句
String sql = "select * from book where name = ?";
Book b = ou.getOne(sql, Book.class, bname);
return b;
}
查询的是书籍表book
【10 分】步骤 6:继续完善 SBDaoImpl
类
/**
* 查询所有书籍中价钱最贵的书籍名称
* @return 返回书籍名称
*/
public String queryExpensiveBook(){
// 请补全sql语句
String sql = "###";
Book b = ou.getOne(sql, Book.class);
return b.getName();
}
答案
public String queryExpensiveBook(){
// 请补全sql语句
String sql = "select * from book order by price DESC limit 1 ";
Book b = ou.getOne(sql, Book.class);
return b.getName();
}
用到排序和分页
【10 分】步骤 7:继续完善 SBDaoImpl
类
/**
* 依据学生的姓名来删除学生
* @param name 学生姓名
* @return 存在名字则删除,并返回true;不存在则不删除,并返回false
*/
public boolean deleteStudent(String name){
// 请补全sql语句
String sql = "###";
int a = ou.delete(sql, name);
if(a>0){
return true;
}else{
return false;
}
}
答案
// 请补全sql语句
String sql = "delete from student where name = ?";
删除的是学生表的数据(如果删除语句没有条件,是删除整个表中的数据)
【10 分】步骤 8:继续完善 SBDaoImpl
类
/**
* 根据学生姓名、旧密码、新密码来更新密码
* 如果学生姓名和旧密码不正确,则不更新
* 如果学生姓名和旧密码正确,则更新
*
* @param name 姓名
* @param oldPwd 旧密码
* @param newPwd 新密码
*/
public void changePwd(String name,String oldPwd,String newPwd){
// 1.先判断学生姓名和旧密码是否正确
// 请补全sql语句
String sql1 = "###";
Student s = ou.getOne(sql1, Student.class, name, oldPwd);
// 2.姓名和旧密码正确,则更新;姓名和旧密码不正确,则不更新
if(s!=null){
// 请补全sql语句
String sql2 = "###";
ou.update(sql2, newPwd, name);
}
}
答案
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);
}
}
【15 分】步骤 9:继续完善 SBDaoImpl
类
/**
* 借书
* @param sb 需要借阅的书籍信息
* @return 借书成功返回true,借书失败返回false
*/
public boolean borrow(SB sb) {
// 1.首先依据要借的书名来获取书籍对象
Book b = findByName(sb.getBname());
// 2.有书则借书,并返回true;没有书则不借书,并返回false
if(b!=null&&b.getNum()>0){
// 往 sb 表中插入相关信息:学生姓名,书籍名称,借书时间。自增id和还书时间不用插入。
// 请补全sql语句
String sql1 = "###";
ou.add(sql1,sb.getSname(),sb.getBname(),DateUtil.convertFromDateToString(sb.getBeginTime()));
// 更新 book 表中对应书籍的数量减1
// 请补全sql语句
String sql2 = "###";
ou.update(sql2, sb.getBname());
return true;
}else{
return false;
}
}
答案
public boolean borrow(SB sb) {
// 1.首先依据要借的书名来获取书籍对象
Book b = findByName(sb.getBname());
// 2.有书则借书,并返回true;没有书则不借书,并返回false
if(b!=null&&b.getNum()>0){
// 往 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());
return true;
}else{
return false;
}
}
在修改SQL的语句中,update book set num-1 where name = ? 是检测失败的
修改语法: update 表名 set 列名1 = 值1,列名2 = 值2... [where]
【15 分】步骤 10:继续完善 SBDaoImpl
类
/**
* 还书
* @param sb 需要归还的书籍信息
* @return 还书成功返回true,还书失败返回false
*/
public boolean giveBack(SB sb){
//1.首先查询某人是否在某个时间借阅了某书,但是还没有归还
// 请补全sql语句
String sql = "###";
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 = "###";
ou.update(sql1, DateUtil.convertFromDateToString(new Date()),sb.getSname(),sb.getBname(),DateUtil.convertFromDateToString(sb.getBeginTime()));
// 更新 book 表中对应书籍的数量加1
// 请补全sql语句
String sql2 = "###";
ou.update(sql2, sb.getBname());
return true;
}else{
return false;
}
}
答案
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;
}
}
与步骤9相似