实验11:20220319 1+X 中级实操考试(id:3097)

(学习笔记:代码块步骤检测都通过了,但是写得标不标准就是另外一回事了....)

实验11与实验7题目要求相差无几

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

复制粘贴即可

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

package org.lanqiao.bean;

public class Student {
    //补充完成该类的含参构造方法
    public Student(String name,String pwd){

    }

}

答案

	//补充完成该类的含参构造方法
	public Student(String name,String pwd){
		this.name = name;
		this.pwd = pwd;
	}

实验11和实验7的区别在于步骤二,11只需要补全有参构造方法,实验7需要手写有参与无参

 【10 分】步骤 3:完成工具类 DateUtilconvertFromStringToDate方法

    /**
     * 使用全局变量: 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;
	}

同时,实验11省略了实验7中的这个方法补全(与7相比11少了下面的步骤)

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

    /**
     * 依据书名查询书籍
     * @param bname 书名
     * @return 有的话返回书籍对象(唯一),没有的话返回null
     */
    public Book findByName(String bname){
        // 请补全sql语句
        String sql = "###";
        Book b = ou.getOne(sql, Book.class, bname);
        return b;
    }

答案

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

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

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

答案

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

 【10 分】步骤 6:继续完善 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 = ?";

 【15 分】步骤 7:继续完善 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);
    }
}

答案

                // 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 分】步骤 8:继续完善 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;
    }
}

答案

                // 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;
                }

 【15 分】步骤 9:继续完善 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;
    }
}

答案

//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;
                }

  • 11
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

长风沛雨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值