满汉楼03

5.拓展_多表查询

前面都是对单表进行操作

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

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


  • 方案一

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

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

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

  • 方案二

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

5.1方案一完成多表查询

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:在里层循环中调用该方法

5.1.2测试

测试通过

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

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

5.1.3细节

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

答案是:要一致。

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

通过反射来获取类的方法

那么新的问题来了->当多表查询的时候,不同的表的列名是一样的,怎么解决呢?

  • 给列起别名

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

6.拓展功能

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

  • 其他功能-登录管理,人事管理,统计报表,成本控制等

    • 登录管理
    • 人事管理--增加、删除、查询、修改员工信息
    • 菜谱价格--增加、删除、查询、修改菜品种类、名称
    • 成本控制



day03-2-拓展的更多相关文章

  1. python开发学习-day03(set集合、collection系列 、深浅拷贝、函数)

    s12-20160116-day03 *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: ...

  2. 2020年12月-第02阶段-前端基础-CSS Day03

    CSS Day03 盒子模型(CSS重点) css学习三大重点: css 盒子模型 . 浮动 . 定位 主题思路: 理解: 1.能说出盒子模型有那四部分组成 2.能说出内边距的作用以及对盒子的影响 3 ...

  3. C++对C的函数拓展

    一,内联函数 1.内联函数的概念 C++中的const常量可以用来代替宏常数的定义,例如:用const int a = 10来替换# define a 10.那么C++中是否有什么解决方案来替代宏代码 ...

  4. RabbitMQ + PHP (二)AMQP拓展安装

    上篇说到了 RabbitMQ 的安装. 这次要在讲案例之前,需要安装PHP的AMQP扩展.不然可能会报以下两个错误. 1.Fatal error: Class 'AMQPConnection' not ...

  5. chrome拓展开发实战:页面脚本的拦截注入

    原文请访问个人博客:chrome拓展开发实战:页面脚本的拦截注入 目前公司产品的无线站点已经实现了业务平台组件化,所有业务组件的转场都是通过路由来完成,而各个模块是通过requirejs进行统一管理, ...

  6. 搭建LNAMP环境(七)- PHP7源码安装Memcached和Memcache拓展

    上一篇:搭建LNAMP环境(六)- PHP7源码安装MongoDB和MongoDB拓展 一.安装Memcached 1.yum安装libevent事件触发管理器 yum -y install libe ...

  7. jQuery的DOM操作实例(2)——拖拽效果&&拓展插件

    一.原生JavaScript编写拖拽效果 二.jQuery编写的拖拽效果 三.在jQuery中拓展一个拖拽插件

  8. 使用TypeScript拓展你自己的VS Code!

    0x00 前言 在前几天的美国纽约,微软举行了Connect(); //2015大会.通过这次大会,我们可以很高兴的看到微软的确变得更加开放也更加务实了.当然,会上放出了不少新产品和新功能,其中就包括 ...

  9. Unity、c#中的拓展方法讲解

    很早以前看过这个东西,但是没有真正的用到过,希望之后会用到上面的方法, 大概的意思是这样的c#中尤其在用Unity的时候,已有的框架提供给我们一些固定的方法,但是有时我们想对这些方法进行修改, 这时我 ...

  10. 关于java中自增,自减,和拓展运算符的小讨论

    java中运算符很多,但是能深入讨论的不算太多.这里我仅仅以++,*=为例做讨论. 例:++ i=0; i=i++ + ++i;//i=1 i=++i+i++;//i=2 i=i++ -++i;//i ...

随机推荐

  1. 技术分析 | 浅谈在MySQL体系下SQL语句是如何在系统中执行的及可能遇到的问题

    欢迎来到 GreatSQL社区分享的MySQL技术文章,如有疑问或想学习的内容,可以在下方评论区留言,看到后会进行解答 SQL语句大家并不陌生,但某种程度上来看,我们只是知道了这条语句是什么功能,它可 ...

  2. php YII2空数组插入报错问题处理 Array to string conversion

    问题描述 前端传空数组 [],php接收后处理不当插入数据库时报错Array to string conversion 参数示例 { "id": 0, //ID整型 "t ...

  3. DS二叉树——二叉树之数组存储

    题目描述 二叉树可以采用数组的方法进行存储,把数组中的数据依次自上而下,自左至右存储到二叉树结点中,一般二叉树与完全二叉树对比,比完全二叉树缺少的结点就在数组中用0来表示.,如下图所示 从上图可以看出 ...

  4. Fiddler抓包工具下载安装及使用

    一.Fiddler简介 简介: Fiddler是一款强大的Web调试工具,他能记录所有客户端和服务器的HTTP/HTTPS请求 工作原理: Fiddler是以代理web服务器的形式工作的,它使用代理地 ...

  5. 058_末晨曦Vue技术_过渡 & 动画之过渡的类名

    进入/离开 & 列表过渡 点击打开视频讲解更加详细 概述 Vue 在插入.更新或者移除 DOM 时,提供多种不同方式的应用过渡效果.包括以下工具: 在 CSS 过渡和动画中自动应用 class ...

  6. KingbaseES R6 集群repmgr.conf参数'recovery'测试案例(二)

    案例二:测试'recovery = automatic' 1.查看集群节点状态信息: [kingbase@node1 bin]$ ./repmgr cluster show ID | Name | R ...

  7. LFS(Linux From Scratch)构建过程全记录(三):下载所需的软件包

    写在前面 本文将记录构建LFS的过程中,下载软件包的全过程 准备下载的路径 注意请确保$LFS已经设置完毕 我们需要创建一个文件夹,地址为$LFS/sources,用于保存对应的源码 输入的指令如下: ...

  8. Elasticsearch高级检索之使用单个字母数字进行分词N-gram tokenizer(不区分大小写)【实战篇】

    一.前言 小编最近在做到一个检索相关的需求,要求按照一个字段的每个字母或者数字进行检索,如果是不设置分词规则的话,英文是按照单词来进行分词的. 小编以7.6.0版本做的功能哈,大家可以根据自己的版本去 ...

  9. ConcurrentDictionary<T,V> 的这两个操作不是原子性的

    好久不见,马甲哥封闭居家半个月,记录之前遇到的一件小事. ConcurrentDictionary<TKey,TValue>绝大部分api都是线程安全且原子性的, 唯二的例外是接收工厂委托 ...

  10. 【gRPC】C++异步服务端优化版,多服务接口样例

    官方的C++异步服务端API样例可读性并不好,理解起来非常的费劲,各种状态机也并不明了,整个运行过程也容易读不懂,因此此处参考网上的博客进行了重写,以求顺利读懂. C++异步服务端实例,详细注释版 g ...