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

实验8:20211030 1+X 中级实操考试(id:2498)目录 5 分 步骤 1 项目准备 5 分 步骤 2 完成实体类 Member 10 分 步骤 3 完成实体类 Goods 10 分 步骤 4 完成工具类 DateUtil 的 convertFromS 方法 10 分 步骤 5 完成工具类

大家好,我是讯享网,很高兴认识大家。

目录

【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

序号 类属性 表字段 数据库数据类型 备注
1 name name VARCHAR 主键
2 price price FLOAT
3 num num INT
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 个字段,详情如下:

表字段 数据库数据类型 备注 备注
name VARCHAR 商品名称 主键
price INT 商品单价
num INT 商品数量

所以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进行字符串反转

表字段 数据库数据类型 含义 备注
name VARCHAR 会员姓名 主键
pwd VARCHAR 会员密码
score FLOAT 会员积分
rank INT 会员等级

答案

 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 个字段,详情如下:

表字段 数据库数据类型 含义 备注
id INT 订单号
mname VARCHAR 会员姓名 外键->会员表(name)
gname VARCHAR 商品名称 外键->商品表(name)
num INT 商品数量
price FLOAT 商品单价

答案:

 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进行查询

小讯
上一篇 2025-01-30 07:04
下一篇 2025-01-18 08:34

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/15369.html