mysql使用group by查詢報錯SELECT list is not in GROUP BY clause and contains nonaggregated column...原因及解決方案

来源:https://www.cnblogs.com/zmdComeOn/archive/2022/03/26/16061090.html
-Advertisement-
Play Games

在項目中需要用到group by進行聚合計算,在計算的同時也要查出一些其他欄位來返回給前端。於是就有了這個錯誤的出現。 先簡單復現我所寫的sql,其實sql非常簡單。 select channel_name as channelName, brand_name as brandName, sum(a ...


在項目中需要用到group by進行聚合計算,在計算的同時也要查出一些其他欄位來返回給前端。於是就有了這個錯誤的出現。

先簡單復現我所寫的sql,其實sql非常簡單。

select
channel_name as channelName,
brand_name as brandName,
sum(actual_value) as actualValue,
sum(actual_value_ty) as actualValueTy,
sum(actual_value_ly) as actualValueLy,
sum(target_value) as targetValue
from bu_channel_base_performance
group by channel_name
然後就是這樣一段sql在運行時候報錯如標題所示,

這種模式的官方解釋:ONLY_FULL_GROUP_BY是MySQL資料庫提供的一個sql_mode, 通過這個 sql_mode 來保證, SQL語句 “分組求最值” 合法性的檢查. 這種模式採用了與 Oracle、DB2 等資料庫的處理方式。即不允許 select target list 中出現語義不明確的列.
對於用到 GROUP BY 的 select 語句, 查出來的列必須是 group by 後面聲明的列, 或者是聚合函數裡面的列有這樣一個資料庫的表.
因此,這種模式的特點是:

1:只要有聚合函數 sum(),count(),max(),avg() 等函數就需要用到 group by , 否則就會報上面的錯誤.
2:group by id (id 是主鍵) 的時候, select 什麼都沒有問題, 包括有聚合函數.
3:group by role (非主鍵) 的時候, select 只能是聚合函數和 role ( group by 的欄位) , 否則報錯

 

而解決方案,大家則都是給出了相同的方案,修改mysql配置文件,即:

select @@sql_mode;
先查看自己mysql的mode配置,一般不出意外都是:ONLY_FULL_GROUP_BY。

此時,方案就是修改sql_mode:

sql_mode="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION"

倘若你通過修改sql能夠解決問題而不影響你的結果,那麼個人認為最好是優先修改sql。

作者:子欽加油
出處:https://www.cnblogs.com/zmdComeOn/
個性簽名:努力生活,努力走路
阿裡雲拼團:https://www.aliyun.com/1111/home?userCode=f4ee1llo1核2G1M,86一年,229三年;2核4G5M,799三年;2核8G5M,1399三年
騰訊雲三月採購計劃特價:https://cloud.tencent.com/act/cps/redirect?redirect=1073&cps_key=15d0b1673287c43fe946626d9f4e2eee&from=console1核2G1M,88一年;1核2G1M,268三年;2核4G5M,998一年;4核8G5M,2888元三年

您的資助是我最大的動力!
金額隨意,歡迎來賞!

如果,想給予我更多的鼓勵,求打
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 這是Flutter系列第一篇文章,後續會持續更新Flutter相關知識,本篇就主要對於Flutter技術做一個簡單的入門介紹 一、Flutter簡介🔥 Flutter是谷歌的移動UI框架,可以快速在iOS和Android上構建高質量的原生用戶界面。 Flutter可以與現有的代碼一起工作。在全世界 ...
  • 經過前面四天的學習,對Node.js已經有了一個基礎的認識,今天繼續學習Node.js網路通信編程相關內容,並稍加整理加以分享,如有不足之處,還請指正。 ...
  • 這篇文章分享一下我收集到的有關數據扁平化的一些見解和案例,希望對大家有所幫助 什麼是扁平化 數組的扁平化,就是將一個嵌套多層的數組 array (嵌套可以是任何層數)轉換為只有一層的數組。 舉個例子,假設有個名為 flatten 的函數可以做到數組扁平化,效果就會如下: var arr = [1, ...
  • 1、break: 翻譯成中文是打斷、中斷的意思,作用是結束當前的迴圈體,後面的迴圈也不再繼續了,經常使用在for、while迴圈裡面; 2、continue: 翻譯成中文是繼續、延續的意思,作用是跳出本次迴圈,繼續執行下一次迴圈(不是繼續執行當前次迴圈),和break最大的區別就是還會繼續執行下一個 ...
  • JavaWeb-CSS 部分圖片不能提取 具體的編寫規則可以參考樣式表中文手冊(網上可以直接下載) CSS:層疊式樣式表,決定頁面的美觀程度 CSS語法 基礎語法 <!-- 1.CSS最基本的分類:標簽樣式表,類樣式表,ID樣式表 2.CSS從位置位置上的分類:嵌入式樣式表,內部式樣式表,外部時樣式 ...
  • Javascript中的for是如何實現迴圈的? 一、語法結構 單for迴圈 for (初始化變數; 條件表達式; 操作表達式) { 迴圈體 } 雙重for迴圈(也叫迴圈嵌套) for (外層初始化變數; 外層的表達式; 外層的操作表達式) { for (裡層的初始化變數; 裡層的條件表達式; 裡層 ...
  • 裝飾器模式是什麼 是一種結構型設計模式,它允許你將對象放入包含行為的特殊封裝對象中來為原對象綁定新的行為。由於目標對象和裝飾器遵循同一介面,所以你可以對目標進行多次裝飾,最後結果為所有裝飾器疊加的行為。 為什麼用裝飾器模式 需要動態的給一個對象增加功能,並且可以動態的撤銷的時候。當系統需要添加新的功 ...
  • 編寫一個程式,獲取10個1至20的隨機數,要求隨機數不能重覆。 * * 分析: * A:創建隨機數對象 * B:創建一個HashSet集合 * C:判斷集合的長度是不是小於10 * 是:就創建一個隨機數添加 * 否:不搭理它 * D:遍歷HashSet集合 */ package Day17; imp ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...