实验8: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

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

答案:

    public Member(){
​
    }
    public Member(String name,String pwd, float score, int rank){
        this.name = name;
        this.pwd = pwd;
        this.score = score;
        this.rank = rank;
    }

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

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

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

答案:

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

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

【10 分】步骤 4:完成工具类 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;
	}
提示

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

beginDate = format.parse(contentList.get(0)[3].toString());

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

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

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

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

要求:把日期转成字符串

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

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

答案:

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

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

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

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

goods

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

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

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

答案:

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

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

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

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

    /**
     * 查询所有商品的总价值金额
     * @return 返回所有商品的总价值金额
     */
    public double querySum() {
        String sql = "select * from goods";
        double sum = 0;
        List<Goods> list = goodsUtil.getList(sql, Goods.class);
        for (Goods goods : list) {
            // 请补全代码
           
           
        }
        return sum;
    }
}

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

答案:

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

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

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

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

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

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

答案

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

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

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

————Java中的reverse() --- 字符串反转————​​​​​​​

以下实例演示了如何使用 Java 的反转函数 reverse() 将字符串反转:

public class StringReverseExample{
   public static void main(String[] args){
      String string="runoob";
      String reverse = new StringBuffer(string).reverse().toString();
      System.out.println("字符串反转前:"+string);
      System.out.println("字符串反转后:"+reverse);
   }
}
以上代码实例输出结果为:

字符串反转前:runoob
字符串反转后:boonur
(菜鸟编程)

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

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

答案:

	public void updateRank() {
                // 请补全sql语句
                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)";
                memberUtil.update(sql); 
        }
​
思路:使用了 case WHEN.... then ... WHEN ... then ... then ... END

CASE WHEN是列出几个并行的条件,几个情况都是并列的,优先级从前往后。

when判断的条件是对会员表中score(会员积分)字段的查询 between ... and ... 在?到?的范围内(包含)查找,然后由then给出结果,在通过when并列提出条件继续查找,结尾由end结束

——扩展——

mysql中case when then end的含义和用法

简单的函数形式 case 字段 when 值 then 结果 else 其他情况 end;

表达式的形式 case when 字段=值(这里写表达式,例如 score=80) then 结果 else 其他情况 end;

简单的函数形式
select case score when 'a' then '优秀' else '良好' end from student;
​
表达式形式
select case when  score between 90 and 100  then '优秀' else '良好' end from student;
​
(扩展来源:(31条消息) mysql中case when then end的含义和用法IT_Boy_QI的博客-CSDN博客case when是什么意思)

​

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

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

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

order

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

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

答案:

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

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

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

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

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

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

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

答案:

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

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

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

  • 5
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

长风沛雨

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

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

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

打赏作者

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

抵扣说明:

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

余额充值