滿漢樓03 5.拓展_多表查詢 前面都是對單表進行操作 思考一個問題:如果多表查詢怎麼處理?例如,查看賬單時,希望現實菜品名稱 查詢的結果從上圖變為下圖: 方案一 由多張表組合查詢的的結果,我們仍然可以將其映射成一個Javabean 例如MultTableBean類,該類的屬性可以來自多張表的欄位, ...
滿漢樓03
5.拓展_多表查詢
前面都是對單表進行操作
思考一個問題:如果多表查詢怎麼處理?例如,查看賬單時,希望現實菜品名稱
查詢的結果從上圖變為下圖:
- 方案一
由多張表組合查詢的的結果,我們仍然可以將其映射成一個Javabean
例如MultTableBean類,該類的屬性可以來自多張表的欄位,即該類跟多張表進行映射
在這基礎上,仍然可以使用之前的想法:在Dao層創建一個新的dao類,該類專門用於多表操作,在service層也創建相應的service類(根據實際情況),供界面層調用等
- 方案二
5.1方案一完成多表查詢
以menu表和dill表為例
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
- 其他功能-登錄管理,人事管理,統計報表,成本控制等
- 登錄管理
- 人事管理--增加、刪除、查詢、修改員工信息
- 菜譜價格--增加、刪除、查詢、修改菜品種類、名稱
- 成本控制