赞
踩
目录
【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 方法
复制粘贴
- 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
序号 | 类属性 | 表字段 | 数据库数据类型 | 备注 |
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在这个范围内赋值就可以了
- /**
- * 使用全局变量: 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)));
- /**
- * 使用全局变量: 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);
- }
- /**
- * 查询所有商品中价钱最贵的商品名称
- * @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条数据
- /**
- * 查询所有商品的总价值金额
- * @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
- /**
- * 给每个会员的密码加密
- * 加密规则:密码的逆序。
- * 如:原来的密码是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
- (菜鸟编程)
- /**
- * 根据会员的积分来更新会员的等级
- * 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是什么意思)
-
-
- /**
- * 查询一共有多少笔订单
- * @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个订单
- /**
- * 查询消费金额最多的人
- * @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进行查询
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。