"SELECT語句中的非聚合列未在GROUP BY子句中出現,與sql_mode=only_full_group_by不相容"
P粉034571623
2023-08-20 13:44:52
<p>我正在使用MySQL 5.7.13在我的Windows PC上使用WAMP伺服器</p>
<p>我的問題是執行這個查詢時</p>
<pre class="brush:php;toolbar:false;">SELECT *
FROM `tbl_customer_pod_uploads`
WHERE `load_id` = '78' AND
`status` = 'Active'
GROUP BY `proof_type`</pre>
<p>我總是得到這樣的錯誤</p>
<blockquote>
<p>SELECT列表中的表達式#1不在GROUP BY子句中,並且包含非聚合列'returntr_prod.tbl_customer_pod_uploads.id',該列在GROUP BY子句中的列上沒有函數依賴性;這與sql_mode=only_full_group_by不相容</p>
</blockquote>
<p>請告訴我最好的解決方案。 </p>
<p>我需要的結果如下</p>
<pre class="brush:php;toolbar:false;"> ---- --------- --------- --------- -- -------- ----------- ------------ --------------- ---- ---------- ------------ -------- -------------------- - ---------------------
| id | user_id | load_id | bill_id | latitude | langitude | proof_type | document_type | file_name | is_private | status | createdon | updatedon |
---- --------- --------- --------- ---------- --------- -- ------------ --------------- -------------- ------- ----- -------- --------------------- ---------------- -----
| 1 | 1 | 78 | 1 | 21.1212 | 21.5454 | 1 | 1 | id_Card.docx | 0 | Active | 2017-01-27 11:30:11 | 2017-01-27 11:30:14 |
---- --------- --------- --------- ---------- --------- -- ------------ --------------- -------------- ------- ----- -------- --------------------- ---------------- ----- </pre>
<p><br /></p>
在MySQL引擎中有一個系統變數
ONLY_FULL_GROUP_BY
。從MySQL版本5.7.5開始:預設啟用
ONLY_FULL_GROUP_BY
SQL模式。在5.7.5版本之前:預設未啟用
ONLY_FULL_GROUP_BY
。如果啟用了
ONLY_FULL_GROUP_BY
SQL模式(從5.7.5版本開始預設啟用),MySQL將拒絕查詢選擇清單、HAVING
條件或ORDER BY
#清單引用非聚合列,這些列既不在GROUP BY
子句中命名,也不與其功能相關。為了解決這個問題,請使用以下三個解決方案之一
(1) PHPMyAdmin
停用:
ONLY_FULL_GROUP_BY
模式如果您使用的是phpMyAdmin,則根據下面的截圖變更
sql_mode
設定。#編輯
sql mode
變數並從值中刪除ONLY_FULL_GROUP_BY
文字或
(2) SQL/命令提示字元
透過執行下列指令停用:
ONLY_FULL_GROUP_BY
模式。或
(3) 不要使用
SELECT *
不要停用
ONLY_FULL_GROUP_BY
模式,而是在
SELECT
查詢中使用相關欄位。相關列指的是group by
子句中出現的欄位或帶有聚合函數(MAX
、MIN
、##SUM、
COUNT等)的欄位
重要提示
使用點(1)或點(2)
因此,您應該在設定檔中設定此項目(例如,在進行的更改不是永久設置,每次重新啟動後都會還原。
[mysqld]
部分的
/etc/mysql/my.cnf檔案中),以便在MySQL重新啟動後保持變更生效:
設定檔:/etc/mysql/my.cnf
#變數名稱:sql_mode
或 #sql-mode
#從值中刪除ONLY_FULL_GROUP_BY
一詞並儲存檔案。
注意:如果在設定檔中找不到sql_mode
變量,請在檔案結尾插入以下2行
這個問題可以透過在MySQL中更改sql模式來簡單解決,使用以下命令:
對我也有效...
我使用了這個方法,因為在我的專案中有很多類似的查詢,所以我只是將sql模式更改為only_full_group_by。
或簡單地在GROUP BY子句中包含SELECT語句指定的所有欄位。可以保持啟用sql_mode。
謝謝... :-)
更新日期:2023年7月14日
更改SQL模式是一種解決方法,但是對於結構化查詢語言的最佳實踐是避免選擇所有(SELECT * ...)列,而是在分組列上使用聚合函數,如@Tim Biegeleisen在以下的回答中提到的https://stackoverflow.com/a/41887524/3602846
#