实验13:20210620 Java大数据1+X 中级实操考试(id:2496)

一、项目背景说明

图书管理系统是学校、图书馆等单位使用的一套系统,本项目使用控制台来模拟其部分功能。

  • 在图书管理系统里面,涉及到的类有:学生类 Student、书籍类 Book、借阅信息类 SB。
  • 对应的数据表有:学生表 student、书籍表 book、借书还书表 sb。
  • 功能主要涉及到:登录、查看浏览书籍、借阅书籍、归还书籍、个人信息管理等。

二、表结构

  • 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 归还时间

三、步骤

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

复制粘贴、略。

【5 分】步骤 2:完成实体类 Student

题目:

首先我们要设计一系列的实体类,它们是 org.lanqiao.bean.Student、org.lanqiao.bean.Book、org.lanqiao.bean.SB, Book 和 SB 我们已经完成了,现在 Student 类需要你来完成。

org.lanqiao.bean.Student是一个实体类,有两个属性,与数据库表 student 及其字段一一对应,对应关系如下。

【数据库表 student 的字段及其与实体类 Student 的属性的对应关系】

序号 类属性 表字段 数据库数据类型 备注
1 name name VARCHAR 主键
2 pwd pwd VARCHAR

请根据注释要求,补全空缺的代码。

package org.lanqiao.bean;

public class Student {
    
    
    private String name;
    private String pwd;
    //已经提供Student类的属性,补充完成该类的有参(两个参数)及无参构造方法


}

答案:

//已经提供Student类的属性,补充完成该类的有参(两个参数)及无参构造方法
public Student(){
    
    }

public Student(String name, String pwd){
    
    
	this.setName(name);
	this.setPwd(pwd);
}

【10 分】步骤 3:完成工具类 DateUtil的convertFromStringToDate方法

题目:

在项目中我们需要用到日期和字符串类型的相互转换,我们把这些功能封装到 org.lanqiao.util.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) {
    
    
		// TODO: handle exception
	}

	return date;
}

【10 分】步骤 4:完成工具类 DateUtil的convertFromDateToString 方法

题目:

请根据注释要求,补全org.lanqiao.util.DateUtil 的 convertFromDateToString 方法。

    /**
     * 使用全局变量: sdf,将日期转换成字符串
     * @param date 需要被转换的日期
     * @return 转换之后的字符串形式的日期
     */
    public static String convertFromDateToString(Date date) {
    
    
        // 补全或替换代码
        return null;
    }

答案:

public static String convertFromDateToString(Date date) {
    
    
	// 补全或替换代码
	return sdf.format(date);
}

【10 分】步骤 5:完成 SBDaoImpl 的 findByName 方法

题目:

数据存入数据库之后,我们需要进行相关的 CRUD,进行数据的处理和展示,数据库的操作我们封装到 org.lanqiao.daoimpl.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;
}

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

题目:

请根据注释要求,补全 queryExpensiveBook 方法。

/**
* 查询所有书籍中价钱最贵的书籍名称
* @return 返回书籍名称
*/
public String queryExpensiveBook(){
    
    
    // 请补全sql语句
    String sql = "###";
    Book b = ou.getOne(sql, Book.class);
    return b.getName();
}

答案:

public String queryExpensiveBook(){
    
    
        // 请补全sql语句
        String sql = "select name from book where price = (select max(price) from book)";
        Book b = ou.getOne(sql, Book.class);
        return b.getName();
}

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

题目:

请根据注释要求,补全 deleteStudent 方法。

/**
* 依据学生的姓名来删除学生
* @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;  
  }
}

答案:

public boolean deleteStudent(String name){
    
    
        // 请补全sql语句
        String sql = "delete from student where name=?";
        int a = ou.delete(sql, name);
        if(a>0){
    
    
                return true;
        }else{
    
    
                return false;  
        }
}

【10 分】步骤 8:继续完善 SBDaoImpl 类

题目:

请根据注释要求,补全 changePwd 方法。

/**
* 根据学生姓名、旧密码、新密码来更新密码
* 如果学生姓名和旧密码不正确,则不更新
* 如果学生姓名和旧密码正确,则更新
*
* @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 类

题目:

请根据注释要求,补全 borrow 方法。

/**
* 借书
* @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 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;
        }
}

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

题目:

请根据注释要求,补全 giveBack 方法。


/**
* 还书
* @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=? and endtime is null";
        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;
        }
}

猜你喜欢

转载自blog.csdn.net/realoser/article/details/131076182
今日推荐