首页 > 其他分享 >day03-2-拓展

day03-2-拓展

时间:2022-10-21 22:56:44浏览次数:92  
标签:return String day03 void 拓展 private Integer public

满汉楼03

5.拓展_多表查询

前面都是对单表进行操作

思考一个问题:如果多表查询怎么处理?例如,查看账单时,希望现实菜品名称

查询的结果从上图变为下图:

image-20221021181451199 image-20221021181508799
  • 方案一

由多张表组合查询的的结果,我们仍然可以将其映射成一个Javabean

例如MultTableBean类,该类的属性可以来自多张表的字段,即该类跟多张表进行映射

在这基础上,仍然可以使用之前的想法:在Dao层创建一个新的dao类,该类专门用于多表操作,在service层也创建相应的service类(根据实际情况),供界面层调用等

  • 方案二

DBUtils数据库连接池多表连接查询-CSDN博客

5.1方案一完成多表查询

以menu表和dill表为例

image-20221021225008865

image-20221021224945925

5.1.1代码实现

1.创建MultiTableBean类
package com.li.mhl.domain;

import java.util.Date;

public class MultiTableBean {
    private Integer id;
    private String billId;
    private Integer menuId;
    private Integer nums;
    private Double money;
    private Integer diningTableId;
    private Date billDate;
    private String state;
    //增加menu表的字段
    private String name;
    private Double price;

    public MultiTableBean() {
    }

    public MultiTableBean(Integer id, String billId, Integer menuId, Integer nums, Double money, Integer diningTableId, Date billDate, String state, String name, Double price) {
        this.id = id;
        this.billId = billId;
        this.menuId = menuId;
        this.nums = nums;
        this.money = money;
        this.diningTableId = diningTableId;
        this.billDate = billDate;
        this.state = state;
        this.name = name;
        this.price = price;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getBillId() {
        return billId;
    }

    public void setBillId(String billId) {
        this.billId = billId;
    }

    public Integer getMenuId() {
        return menuId;
    }

    public void setMenuId(Integer menuId) {
        this.menuId = menuId;
    }

    public Integer getNums() {
        return nums;
    }

    public void setNums(Integer nums) {
        this.nums = nums;
    }

    public Double getMoney() {
        return money;
    }

    public void setMoney(Double money) {
        this.money = money;
    }

    public Integer getDiningTableId() {
        return diningTableId;
    }

    public void setDiningTableId(Integer diningTableId) {
        this.diningTableId = diningTableId;
    }

    public Date getBillDate() {
        return billDate;
    }

    public void setBillDate(Date billDate) {
        this.billDate = billDate;
    }

    public String getState() {
        return state;
    }

    public void setState(String state) {
        this.state = state;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Double getPrice() {
        return price;
    }

    public void setPrice(Double price) {
        this.price = price;
    }

    @Override
    public String toString() {
        return id +
                "\t\t" + menuId +
                "\t\t\t" + name +
                "\t\t" + price +
                "\t\t" + nums +
                "\t\t\t" + money +
                "\t\t" + diningTableId +
                "\t\t" + billDate +
                "\t\t" + state;
    }
}
2.创建MultiTableDAO类
package com.li.mhl.dao;

import com.li.mhl.domain.MultiTableBean;

/**
 * @author 李
 * @version 1.0
 */
public class MultiTableDAO extends BasicDAO<MultiTableBean>{

}
3.修改BillService类

这里为了简单,不再创建MultiTableService,直接在BillService类中增加方法

修改处1:

//定义MultiTableDAO属性
private MultiTableDAO multiTableDAO = new MultiTableDAO();

修改处2:

//改进后的方法--返回所有的账单,提供给View使用
public List<MultiTableBean> list2() {
    return multiTableDAO.queryMulti("SELECT " +
                    "bill.id,menuId,NAME,price,nums,money,diningTableId,state,billDate " +
                    "FROM bill,menu WHERE menuId=menu.id",
            MultiTableBean.class);
}
4.修改MHLView类

修改处1:在该类中增加方法listBill2()

//显示账单信息-改进
public void listBill2() {
    List<MultiTableBean> multiTableBeans = billService.list2();
    System.out.println("\n编号\t\t菜品号\t\t菜品名\t\t单价\t\t\t菜品量\t\t金额\t\t\t桌号\t\t日期\t\t\t\t\t\t\t状态");
    for (MultiTableBean multiTableBean : multiTableBeans) {
        System.out.println(multiTableBean);
    }
    System.out.println("============显示完毕============");
}

修改处2:在里层循环中调用该方法

image-20221021193527324

5.1.2测试

image-20221021193631220

测试通过


后面想要跟别的表进行关联,只要在MultiTableBean中增加相应的属性字段,修改构造器,并增加相应的get和set方法。在对应的Service类中修改sql语句即可

可以根据业务来拆分MultiTableBean,分为不同的MultiTableBeanxxx

5.1.3细节

  1. 关于上面的方案,还存在一个问题,javabean的属性名是否一定要和表的列名一致?

    答案是:要一致。

    原因是:在对查询记录进行封装的时候,要根据列名Xxx来找到对应Javabean的setXxx方法,即根据列名来把列的值设置给Javabean的属性

    通过反射来获取类的方法

  2. 那么新的问题来了->当多表查询的时候,如果存在不同表的列名是一样的情况,怎么解决呢?

    答案是给列起别名

    在sql语句查询的时候,给重名的列起别名。查询列名变了,根据列名调用的对象的setXxx方法就不会冲突。

6.拓展功能

  • 员工信息的字段可能会很多,而且员工数可能也会很多,为了提高效率,可以采用分表设计employee和login

    image-20221021224006367

image-20221021222052519

  • 其他功能-登录管理,人事管理,统计报表,成本控制等
    • 登录管理
    • 人事管理--增加、删除、查询、修改员工信息
    • 菜谱价格--增加、删除、查询、修改菜品种类、名称
    • 成本控制
image-20221021222507062
image-20221021222637649
image-20221021222526554

标签:return,String,day03,void,拓展,private,Integer,public
From: https://www.cnblogs.com/liyuelian/p/16815023.html

相关文章

  • Spring_day03
    Spring_day03今日目标理解并掌握AOP相关概念能够说出AOP的工作流程能运用AOP相关知识完成对应的案例编写重点掌握Spring的声明式事务管理1,AOP简介前面我们在介......
  • 【C++入门】(九)使用继承拓展类
    1.什么是继承?基类(classAnimal)可以有多个派生类(classDog:publicAnimal)classAnimal//基类{public:stringname="123";intage;};​classDo......
  • 力扣_剑指Offer_个人题解day03
    day03剑指Offer05.替换空格题目描述:请实现一个函数,把字符串s中的每个空格替换成"%20"。示例1:输入:s="Wearehappy."输出:"We%20are%20happy."限制:0<=s的长度......
  • Python教程Day03-Python输出、输入、转换数据类型、运算符
    一、输出作用:程序输出内容给用户print('helloPython')age=18print(age)#需求:输出“今年我的年龄是18岁”1、格式化输出格式化输出即按照一定的格式输出内容1.1格......
  • 基本数据类型以及拓展
    publicclassBasicSyntax{publicstaticvoidmain(String[]args){System.out.println("laoliu");/***八大基本数据类型**///整数int......
  • 对象拓展
    属性的简洁表示法使用简写属性的办法:constbaz={foo};等价于constbaz={foo:foo};ES6表达对象的新形式,使用表达式的情况:letpropkey="dd";letobj={[p......
  • 拓展运算符的使用
    拓展运算符的使用拓展运算符:用于快速展开数组或者对象,将数组或者对象中的值一个一个的拿出来单独使用注意点:拓展运算符,和rest参数有点像.但是不是一回事 拓展运算......
  • 基本类型拓展知识
    浮点数拓展浮点数分为float和double浮点数所表示出来的数是有限的,是接近数但是不等于数;所以浮点数是不能用来作比较的作比较可以用BigDecimal(教学工具类)publicclassS......
  • Day03
    3.3方法定义方法方法就是把函数放在对象里面,对象只有两个东西:属性和方法varxcl={  name:'昌隆',  birth:2000,  //方法  age:function(){   ......
  • Day03-java学习记录
    类型转换由于Java是强类型语言,所以某些运算,需要用到类型转换!低》》》》》》》》》》》》》》》》》高byte,short,char->int->long->float->double强制转换高到低自......