前些天有朋友問到了一個聯表的聚合查詢問題,想到此問題可能很多新手處理都比較棘手,現在特意分享出來。
我們有兩個資料表:
bus表:
user表:
#需求:統計每個人上車數量
如何實現?
第一步:聯表
這種場景肯定需要兩個資料表聯表,我們先不考慮統計,我們先進行兩個數據表聯表。
$data=Db::name('user')->alias('a')->join('bus b','a.user_id=b.user_id')->select()->toArray();
alias是別名,join是聯表的資料表,並且有聯表條件a.user_id=b.user_id,這樣我們就能夠取得到兩個資料表聯表的資料了。
第二步:聚合查詢
#在做聚合查詢前,我們先看下官方手冊的教程。
因為我們最終是要取得統計的數量,所以我們先確定用count()方法,所以我們修改查詢語句:
$data=Db::name('user')->alias('a')->field('count(b.user_id) AS c'')->join('bus b','a.user_id=b.user_id')->select()->toArray();
這其中c,是別名。
我們需要根據user_id這個欄位進行聚合查詢,是根據這個欄位統計的,所以我們一定是group(user_id),也就是依照user_id這個欄位進行分組。
我們繼續修改查詢語句:
$data=Db::name('user')->alias('a')->field('count(b.user_id) AS c')->join('bus b','a.user_id=b.user_id')->group('a.user_id')->select()->toArray();
這樣我們就實現了我們的最終查詢結果。
第三點:注意情況
在上面的查詢語句中,如果mysql是5.7版本,那麼就需要格外注意。例如在mysql5.7中在field中加入a.*,就會報錯:
$data=Db::name('user')->alias('a')->field('a.*,count(b.user_id) AS c')->join('bus b','a.user_id=b.user_id')->group('a.user_id')->select()->toArray(); [object Object]
為什麼會有這樣的錯誤呢?
MYSQL5.7為了更好的效能,對sql_mode的限制。
ONLY_FULL_GROUP_BY: 對於GROUP BY聚合操作的時候,如果在SELECT中的列,沒有在GROUP BY中出現,那麼這個SQL是不合法的,因為列不在GROUP BY從句中,這也就是報錯所在。
我們可以修改mysql配置:
修改/etc/my.cnf,將sql_mode=中的only_full_group_by給刪掉
這樣一個聯表的聚合查詢就實現了,我們遇到這個問題的時候,不要心急,根據最終的需求,一步步的拆分一步步的實現。
以上是從實例講解ThinkPHP6聯表聚合查詢的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文討論了ThinkPHP的內置測試框架,突出了其關鍵功能(例如單元和集成測試),以及它如何通過早期的錯誤檢測和改進的代碼質量來增強應用程序可靠性。

本文討論了在無服務器體系結構中使用ThinkPHP的關鍵注意事項,專注於性能優化,無狀態設計和安全性。它突出了諸如成本效率和可擴展性之類的收益,但也應對挑戰

本文討論了在ThinkPHP微服務中實施服務發現和負載平衡,重點是設置,最佳實踐,集成方法和推薦工具。[159個字符]

ThinkPHP的IOC容器提供了高級功能,例如懶惰加載,上下文綁定和方法注入PHP App中有效依賴性管理的方法。Character計數:159

ThinkPHP具有輕巧的設計,MVC架構和可擴展性。它通過各種功能提高可擴展性,加快開發並提高安全性。

本文概述了使用ThinkPhp和RabbitMQ構建分佈式任務隊列系統,重點是安裝,配置,任務管理和可擴展性。關鍵問題包括確保高可用性,避免常見的陷阱,例如不當


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

記事本++7.3.1
好用且免費的程式碼編輯器

Dreamweaver CS6
視覺化網頁開發工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

SublimeText3漢化版
中文版,非常好用