当前位置:   article > 正文

实验8:20211030 1+X 中级实操考试(id:2498)_20211030 1+x 中级实操考试(id:2498)

20211030 1+x 中级实操考试(id:2498)

目录

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

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

【10 分】步骤 3:完成实体类 Goods

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

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

【10 分】步骤 6:完成 GoodsDaoImpl 的 queryExpensiveGoods方法

【10 分】步骤 7:完成 GoodsDaoImpl的 querySum 方法

【10 分】步骤 8:完成 MemberDaoImpl 的 updatePwd 方法

【10 分】步骤 9:完成 MemberDaoImpl 的 updateRank 方法

【10 分】步骤 10:完成 OrderDaoImpl 的queryNum方法

【10 分】步骤 11:完成 OrderDaoImpl 的 queryMax 方法


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

复制粘贴

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

  1. package org.lanqiao.bean;
  2. public class Member {
  3.    private String name;
  4.    private String pwd;
  5.    private float score;
  6.    private int rank;
  7.    //已经提供Member类的属性,补充完成该类的有参(四个参数)及无参构造方法
  8. }

答案:

  1. public Member(){
  2. }
  3. public Member(String name,String pwd, float score, int rank){
  4. this.name = name;
  5. this.pwd = pwd;
  6. this.score = score;
  7. this.rank = rank;
  8. }

创建有参和无参的构造函数不用写static

【10 分】步骤 3:完成实体类 Goods

序号类属性表字段数据库数据类型备注
1namenameVARCHAR主键
2pricepriceFLOAT
3numnumINT
  1. package org.lanqiao.bean;
  2. public class Goods {
  3.    //请修改该方法,并且在赋值时,商品数量不能超过100
  4.    public void setNum(int num) {
  5.        this.num = num;
  6.   }
  7. }

答案:

  1. //请修改该方法,并且在赋值时,商品数量不能超过100
  2. public void setNum(int num) {
  3. if(num > 100 && num <= 0){
  4. this.num = num;
  5. }
  6. }

注:只需要去做一个if判断,让num在这个范围内赋值就可以了

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

  1.    /**
  2.     * 使用全局变量: sdf,将字符串转换为java.util.Date类型并返回
  3.     * @param stringDate
  4.     * 注意,不能声明任何形式的异常抛出,否则测试用例无法通过
  5.     * @return
  6.     */
  7.    public static Date convertFromStringToDate(String stringDate) {
  8.        // 补全代码:
  9.        Date date = null;
  10.        return date;
  11.   }

答案

  1. public static Date convertFromStringToDate(String stringDate) {
  2. // 补全代码:
  3. Date date = null;
  4. try {
  5. date = sdf.parse(stringDate);
  6. } catch (Exception e) {
  7. //TODO: handle exception
  8. }
  9. return date;
  10. }
  1. 提示
  2. parse函数是把字符串转换成日期
  3. beginDate = format.parse(contentList.get(0)[3].toString());
  4. format函数是把日期转换成字符串
  5. item.add(new Label("date",format.format(beginDate)));

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

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

要求:把日期转成字符串

format函数是把日期转换成字符串

item.add(new Label("date",format.format(beginDate)));

答案:

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

【10 分】步骤 6:完成 GoodsDaoImpl 的 queryExpensiveGoods方法

  1.    /**
  2.     * 查询所有商品中价钱最贵的商品名称
  3.     * @return 返回商品名称
  4.     */
  5.    public String queryExpensiveGoods() {
  6.        // 请补全sql语句
  7.        String sql = "###";
  8.        Goods g = goodsUtil.getOne(sql, Goods.class);
  9.        return g.getName();
  10. }

要求:找到商品中价格最贵的商品名称,并且返回商品名称

goods

该表的含义是 商品,共有 3 个字段,详情如下:

表字段数据库数据类型备注备注
nameVARCHAR商品名称主键
priceINT商品单价
numINT商品数量

所以sql中要查询的表是 goods--商品表

答案:

  1. public String queryExpensiveGoods() {
  2.                // 请补全sql语句
  3.                String sql = "select * from goods order by price DESC limit 1 ";
  4.                Goods g = goodsUtil.getOne(sql, Goods.class);
  5.                return g.getName();
  6.       }

思路:查询的表是goods(商品表)要查询价格最贵的,可以用排序查询 order by

然后把price(商品单价)做一个降序的DESC排序,然后通过分页查询 limit,查询最上面1条数据

【10 分】步骤 7:完成 GoodsDaoImpl的 querySum 方法

  1.    /**
  2.     * 查询所有商品的总价值金额
  3.     * @return 返回所有商品的总价值金额
  4.     */
  5.    public double querySum() {
  6.        String sql = "select * from goods";
  7.        double sum = 0;
  8.        List<Goods> list = goodsUtil.getList(sql, Goods.class);
  9.        for (Goods goods : list) {
  10.            // 请补全代码
  11.          
  12.          
  13.       }
  14.        return sum;
  15.   }
  16. }

要求:查询商品表goods中的所有总价,返回总价金额

答案:

  1. public double querySum() {
  2.                String sql = "select * from goods";
  3.                double sum = 0;
  4.                List<Goods> list = goodsUtil.getList(sql, Goods.class);
  5.                for (Goods goods : list) {
  6.                        // 请补全代码
  7.                    sum += goods.getPrice()*goods.getNum();              
  8.               }
  9.                    return sum;
  10.       }

注:代码块中给了一个变量sum来存放总金额,然后给我们进行了遍历,把表中的每个单价和数量相乘加给总价sum,然后返回sum

【10 分】步骤 8:完成 MemberDaoImpl 的 updatePwd 方法

  1.    /**
  2.     * 给每个会员的密码加密
  3.     * 加密规则:密码的逆序。
  4.     * 如:原来的密码是123,加密后为321。
  5.     */
  6.    public void updatePwd(){
  7.        // 请补全sql语句
  8.        String sql = "###";
  9.        memberUtil.update(sql);
  10.   }

要求:把会员表中的密码字段pwd进行字符串反转

表字段数据库数据类型含义备注
nameVARCHAR会员姓名主键
pwdVARCHAR会员密码
scoreFLOAT会员积分
rankINT会员等级

答案

  1. public void updatePwd(){
  2.                // 请补全sql语句
  3.                String sql = "update member set pwd = reverse(pwd) ";
  4.                memberUtil.update(sql);
  5.       }

思路:修改表数据 update 表名 set 列名 = 值

这里修改会员表member中的字段pwd(密码),使用 reverse() 方法对pwd进行一个反转

  1. ————Java中的reverse() --- 字符串反转————​​​​​​​
  2. 以下实例演示了如何使用 Java 的反转函数 reverse() 将字符串反转:
  3. public class StringReverseExample{
  4.   public static void main(String[] args){
  5.     String string="runoob";
  6.     String reverse = new StringBuffer(string).reverse().toString();
  7.     System.out.println("字符串反转前:"+string);
  8.     System.out.println("字符串反转后:"+reverse);
  9.   }
  10. }
  11. 以上代码实例输出结果为:
  12. 字符串反转前:runoob
  13. 字符串反转后:boonur
  14. (菜鸟编程)

【10 分】步骤 9:完成 MemberDaoImpl 的 updateRank 方法

  1.    /**
  2.     * 根据会员的积分来更新会员的等级
  3.     * 0<=score<100分,等级为0
  4.     * 100<=score<200分,等级为1
  5.     * 200<=score<300分,等级为2
  6.     * 300<=score<400分,等级为3
  7.     * 400<=score<500分,等级为4
  8.     * 500<=score分,等级为5
  9.     * @return
  10.     */
  11.    public void updateRank() {
  12.        // 请补全sql语句
  13.        String sql = "###";
  14.        memberUtil.update(sql);
  15.   }

答案:

  1. public void updateRank() {
  2. // 请补全sql语句
  3. String sql = "update member set `rank` = (case when score between 0 and 99 then 0 when score between 100 and 199 then 1 when score between 200 and 299 then 2 when score between 300 and 399 then 3 when score between 400 and 499 then 4 when score >= 500 then 5 end)";
  4. memberUtil.update(sql);
  5. }
  1. 思路:使用了 case WHEN.... then ... WHEN ... then ... then ... END
  2. CASE WHEN是列出几个并行的条件,几个情况都是并列的,优先级从前往后。
  3. when判断的条件是对会员表中score(会员积分)字段的查询 between ... and ... 在?到?的范围内(包含)查找,然后由then给出结果,在通过when并列提出条件继续查找,结尾由end结束
  4. ——扩展——
  5. mysql中case when then end的含义和用法
  6. 简单的函数形式 case 字段 when 值 then 结果 else 其他情况 end;
  7. 表达式的形式 case when 字段=值(这里写表达式,例如 score=80) then 结果 else 其他情况 end;
  8. 简单的函数形式
  9. select case score when 'a' then '优秀' else '良好' end from student;
  10. 表达式形式
  11. select case when score between 90 and 100 then '优秀' else '良好' end from student;
  12. (扩展来源:(31条消息) mysql中case when then end的含义和用法IT_Boy_QI的博客-CSDN博客case when是什么意思)

【10 分】步骤 10:完成 OrderDaoImpl 的queryNum方法

  1. /**
  2. * 查询一共有多少笔订单
  3. * @return 返回订单数量
  4. */
  5. public int queryNum() {
  6.   String sql = "select * from `order`;";
  7.   List<Order> o = orderUtil.getList(sql, Order.class);
  8.   Set<Integer> s = new HashSet<Integer>();
  9.   for (Order order : o) {
  10.       // 请补全语句
  11.   }
  12.   return s.size();
  13. }

要求:查询共有多少笔订单,返回订单数量

order

该表的含义是 订单,共有 5 个字段,详情如下:

表字段数据库数据类型含义备注
idINT订单号
mnameVARCHAR会员姓名外键->会员表(name)
gnameVARCHAR商品名称外键->商品表(name)
numINT商品数量
priceFLOAT商品单价

答案:

  1. public int queryNum() {
  2.                String sql = "select * from `order`;";
  3.                List<Order> o = orderUtil.getList(sql, Order.class);
  4.                Set<Integer> s = new HashSet<Integer>();
  5.                for (Order order : o) {
  6.                        // 请补全语句
  7.                        s.add(order.getId());
  8.               }
  9.                return s.size();
  10.       }

题目给出的代码块里面,用的是set集合,数据是不能重复的,可以在给出的循环中用集合的 add()方法来添加数据,对集合s进行添加,添加的是订单表中的 订单编号ID。

  1. INSERT INTO `order` VALUES ('1', 'zs', '辣条', 2, 5.2);
  2. INSERT INTO `order` VALUES ('1', 'zs', '面包', 1, 3.5);
  3. INSERT INTO `order` VALUES ('1', 'zs', '可乐', 1, 2.8);
  4. INSERT INTO `order` VALUES ('2', 'ls', '中华', 1, 50.0);
  5. INSERT INTO `order` VALUES ('3', 'ww', '可乐', 2, 2.8);
  6. INSERT INTO `order` VALUES ('4', 'zs', '牙刷', 1, 8.5);
  7. INSERT INTO `order` VALUES ('4', 'zs', '辣条', 3, 5.2);

订单表中的订单编号ID是重复的,一个订单中有多种商品,所以集合s中添加的是重复了订单编号的ID,一共有4个订单

【10 分】步骤 11:完成 OrderDaoImpl 的 queryMax 方法

  1. /**
  2. * 查询消费金额最多的人
  3. * @return 返回会员名称
  4. */
  5. public String queryMax() {
  6.    // 请补全sql语句
  7.    String sql = "###";
  8.    Order o = orderUtil.getOne(sql, Order.class);
  9.    return o.getMname();
  10. }

要求:通过SQL查询出消费金额最高的人

答案:

  1. public String queryMax() {
  2.                // 请补全sql语句
  3.                String sql = "select * from `order` order by (num * price) DESC limit 1 ";
  4.                Order o = orderUtil.getOne(sql, Order.class);
  5.                return o.getMname();
  6.       }

对订单表order进行查询,通过排序order by 去让数量*单价,然后通过降序和分页取到第一个数据

因为@return 返回会员名称是来自订单表中的Mname(),所以对订单表order进行查询

本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
  

闽ICP备14008679号