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

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