day03-2-拓展

来源:https://www.cnblogs.com/liyuelian/archive/2022/10/21/16815023.html
-Advertisement-
Play Games

滿漢樓03 5.拓展_多表查詢 前面都是對單表進行操作 思考一個問題:如果多表查詢怎麼處理?例如,查看賬單時,希望現實菜品名稱 查詢的結果從上圖變為下圖: 方案一 由多張表組合查詢的的結果,我們仍然可以將其映射成一個Javabean 例如MultTableBean類,該類的屬性可以來自多張表的欄位, ...


滿漢樓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
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 題目描述:判斷字元串中重覆次數最多的字元 // 解決思路: // 1.判斷字元重覆的方法 // 創建空數組,利用鍵值對形式對每個字元進行計數 // 用到 採用for迴圈結合if判斷 對象[鍵] 是否有值,無則undefined // arr.charAt(i)取得arr中i索引號下的元素 // 2. ...
  • 安裝nvm、node、npm 下載nvm安裝包,推薦使用1.1.7,我個人使用1.1.8會有中文亂碼的報錯 點擊exe文件,註意修改nvm的安裝根目錄以及node的安裝根目錄,後者是以後管理多版本node的源文件儲存地址 打開系統cmd,依次輸入一下目錄 nvm -version 檢查nvm是否安裝 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 網頁實現列印 可以選擇性的列印某一部分 的vue組件 1.引入 把print.js 下載到本地,然後放在src 下麵添加文件夾里. print.js // 列印類屬性、方法定義 /* eslint-disable */ const Pri ...
  • 1 v-model 1.1 理解 v-model v-model 是 vue3 中的一個內置指令,很多表單元素都可以使用這個屬性,如 input、checkbox 等,咱可以在自定義組件中實現 v-model。v-model 本質上是一個語法糖: 綁定父組件傳遞過來的 modelValue 屬性; ...
  • 一、所需的地形文件和模型以及 CesiumJs 包 操作之前,我們需要兩份對應的文件,一份是地形文件(可無),一份是對應的模型文件,本次展示的模型是轉換成了 3Dtiles 類型的。 如果我們只做基礎的模型展示,只需要引入一個 js 和 一個 css 文件即可 <script src="js/Ces ...
  • 每日演算法 今日是: 1、將字元串轉換為駝峰格式 2、判斷字元串中是否有連續重覆的字元 將字元串轉換成駝峰格式 // css 中經常有類似 background-image 這種通過 - 連接的字元,通過 javascript 設置樣式的時候需要將這種樣式轉換成 backgroundImage 駝峰格 ...
  • 命令模式是一種數據驅動的設計模式,它屬於行為型設計模式。通過使用命令模式,可以極大地降低系統的耦合度。 ...
  • 項目中有一個查重的需求,就類似論文查重這種的需求,我的組長已經寫好了這個 Demo 了,我也挺感興趣的,所以也看了看是如何實現的,看完後,感慨一聲,噢!原來是這樣實現的啊!。現在呢,就記錄下我從中學到的知識! ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...