超市管理系统是超市、商店等单位使用的一套系统,本项目使用控制台来模拟其部分功能。
该表的含义是 会员,共有 4 个字段,详情如下:
表字段 | 数据库数据类型 | 含义 | 备注 |
---|---|---|---|
name | VARCHAR | 会员姓名 | 主键 |
pwd | VARCHAR | 会员密码 | |
score | FLOAT | 会员积分 | |
rank | INT | 会员等级 |
该表的含义是 商品,共有 3 个字段,详情如下:
表字段 | 数据库数据类型 | 备注 | 备注 |
---|---|---|---|
name | VARCHAR | 商品名称 | 主键 |
price | INT | 商品单价 | |
num | INT | 商品数量 |
该表的含义是 订单,共有 5 个字段,详情如下:
表字段 | 数据库数据类型 | 含义 | 备注 |
---|---|---|---|
id | INT | 订单号 | |
mname | VARCHAR | 会员姓名 | 外键->会员表(name) |
gname | VARCHAR | 商品名称 | 外键->商品表(name) |
num | INT | 商品数量 | |
price | FLOAT | 商品单价 |
复制粘贴、略。
题目:
首先我们要设计一系列的实体类,它们是 org.lanqiao.bean.Member、org.lanqiao.bean.Goods、org.lanqiao.bean.Order, 现在 Member 类需要你来完善。
org.lanqiao.bean.Member是一个实体类,有四个属性,与数据库表 member 及其字段一一对应,对应关系如下。
【数据库表 member 的字段及其与实体类 Member 的属性的对应关系】
序号 | 类属性 | 表字段 | 数据库数据类型 | 备注 |
---|---|---|---|---|
1 | name | name | VARCHAR | 主键 |
2 | pwd | pwd | VARCHAR | |
3 | score | score | FLOAT | |
4 | rank | rank | INT |
请根据注释要求,补全空缺的代码。
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.setName(name);
this.setPwd(pwd);
this.setScore(score);
this.setRank(rank);
}
题目:
现在来完善 Goods 商品类。
org.lanqiao.bean.Goods是一个实体类,有三个属性,与数据库表 goods 及其字段一一对应,对应关系如下。
【数据库表 goods 的字段及其与实体类 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;
}
}
答案:
public void setNum(int num) {
if (num > 100) return;
this.num = num;
}
题目:
在项目中我们需要用到日期和字符串类型的相互转换,我们把这些功能封装到 org.lanqiao.util.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;
}
题目:
请根据注释要求,补全org.lanqiao.util.DateUtil 的 convertFromDateToString 方法。
/**
* 使用全局变量: sdf,将日期转换成字符串
* @param date 需要被转换的日期
* @return 转换之后的字符串形式的日期
*/
public static String convertFromDateToString(Date date) {
// 补全或替换代码
return null;
}
答案:
public static String convertFromDateToString(Date date) {
// 补全或替换代码
return sdf.format(date);
}
题目:
数据存入数据库之后,我们需要进行相关的 CRUD,进行数据的处理和展示,数据库中有关商品的操作我们封装到 org.lanqiao.daoimpl.GoodsDaoImpl 里面,请帮忙完成。
请根据注释要求,补全 queryExpensiveGoods 方法。
/**
* 查询所有商品中价钱最贵的商品名称
* @return 返回商品名称
*/
public String queryExpensiveGoods() {
// 请补全sql语句
String sql = "###";
Goods g = goodsUtil.getOne(sql, Goods.class);
return g.getName();
}
答案:
public String queryExpensiveGoods() {
// 请补全sql语句
String sql = "select name from goods where price = (select max(price) from goods)";
Goods g = goodsUtil.getOne(sql, Goods.class);
return g.getName();
}
题目:
数据存入数据库之后,我们需要进行相关的 CRUD,进行数据的处理和展示,数据库中有关商品的操作我们封装到 org.lanqiao.daoimpl.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;
}
}
答案:
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.getNum() * goods.getPrice();
}
return sum;
}
题目:
数据存入数据库之后,我们需要进行相关的 CRUD,进行数据的处理和展示,数据库中有关会员的操作我们封装到 org.lanqiao.daoimpl.MemberDaoImpl 里面,请帮忙完成。
请根据注释要求,补全 updatePwd 方法。
/**
* 给每个会员的密码加密
* 加密规则:密码的逆序。
* 如:原来的密码是123,加密后为321。
*/
public void updatePwd(){
// 请补全sql语句
String sql = "###";
memberUtil.update(sql);
}
答案:
public void updatePwd(){
// 请补全sql语句
String sql = "update member set pwd = reverse(pwd)";
memberUtil.update(sql);
}
题目:
数据存入数据库之后,我们需要进行相关的 CRUD,进行数据的处理和展示,数据库中有关会员的操作我们封装到 org.lanqiao.daoimpl.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 < 100 then 0 "
+ "when scoree < 200 then 1 "
+ "when scoree < 300 then 2 "
+ "when scoree < 400 then 3 "
+ "when scoree < 500 then 4 "
+ "else 5 "
+"end)";
memberUtil.update(sql);
}
题目:
数据存入数据库之后,我们需要进行相关的 CRUD,进行数据的处理和展示,数据库中有关订单的操作我们封装到 org.lanqiao.daoimpl.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();
}
答案:
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();
}
题目:
数据存入数据库之后,我们需要进行相关的 CRUD,进行数据的处理和展示,数据库中有关订单的操作我们封装到 org.lanqiao.daoimpl.OrderDaoImpl 里面,请帮忙完成。
请根据注释要求,补全 queryMax 方法。
/**
* 查询消费金额最多的人
* @return 返回会员名称
*/
public String queryMax() {
// 请补全sql语句
String sql = "###";
Order o = orderUtil.getOne(sql, Order.class);
return o.getMname();
}
答案:
踩坑——字段名上的标点符号 ` 必须加上,否则报错。
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();
}