- 工信部備案號 滇ICP備05000110號-1
- 滇公安備案 滇53010302000111
- 增值電信業務經營許可證 B1.B2-20181647、滇B1.B2-20190004
- 云南互聯網協會理事單位
- 安全聯盟認證網站身份V標記
- 域名注冊服務機構許可:滇D3-20230001
- 代理域名注冊服務機構:新網數碼
下載安裝的是最新版的mysql5.7.x版本,默認是開啟了 only_full_group_by
模式的,但開啟這個模式后,原先的 group by
語句就報錯,然后又把它移除了。
一旦開啟 only_full_group_by
,感覺,group by
將變成和 distinct
一樣,只能獲取受到其影響的字段信息,無法和其他未受其影響的字段共存,這樣,group by
的功能將變得十分狹窄了
only_full_group_by
模式開啟比較好。
因為在 mysql
中有一個函數: any_value(field)
允許,非分組字段的出現(和關閉 only_full_group_by
模式有相同效果)。
[Err] 1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated column 'information_schema.PROFILING.SEQ' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
01 | select @@global.sql_mode; |
ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
01 | set @@global.sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'; |
1 | set sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'; |
一:在sql查詢語句中不需要group by的字段上使用any_value()函數
若我們項目的mysql安裝在ubuntu上面,找到這個文件打開一看,里面并沒有sql_mode這一配置項,想刪都沒得刪。
當然,還有別的辦法,打開mysql命令行,執行命令
1 | select @@sql_mode; |
這樣就可以查出sql_mode的值,復制這個值,在my.cnf中添加配置項(把查詢到的值刪掉only_full_group_by這個選項,其他的都復制過去):
1 | sql_mode=STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION; |
如果 [mysqld] 這行被注釋掉的話記得要打開注釋。然后重重啟mysql服務
注:使用命令
1 | set sql_mode=STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION |
這樣可以修改一個會話中的配置項,在其他會話中是不生效的。
售前咨詢
售后咨詢
備案咨詢
二維碼
TOP