mysql8中如何設置sql-mode
mysql8報錯,
在mysql配置文件下設置
sql_mode=‘NO_AUTO_VALUE_ON_ZERO,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION,PIPES_AS_CONCAT,ANSI_QUOTES'在mysqlld下添加sql-mode
MySQL 5.7.5及以上功能依賴檢測功能。
如果啟用了ONLY_FULL_GROUP_BY
SQL模式(默認情況下),MySQL將拒絕選擇列表,HAVING條件或ORDER BY列表的查詢引用在GROUP BY子句中既未命名的非集合列,也不在功能上依賴于它們。
解決方法一(不推薦):sql設置1、navcat中新建查詢:
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
可以看到存在ONLY_FULL_GROUP_BY,問題就出在這上
2、修改sql_mode
set @@global.sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';注意:“8.0.x的版本不支持NO_AUTO_CREATE_USER,去掉即可”
這樣的方式只能解決單表,且如果Mysql服務重啟(即服務器重啟)則會被mysql的默認ini配置覆蓋,因此不推薦。
解決方法二:修改Mysql的默認配置文件my.ini(推薦)以下為本人的配置:
[mysqld]# 設置3307端口(原先的mysql5已經占用3306)port=3307# 設置mysql的安裝目錄(你自己的目錄)basedir='D:\\Environment\\mysql-8.0.30-winx64'# 設置mysql數據庫的數據的存放目錄datadir='D:\\Environment\\mysql-8.0.30-winx64\\data'# 允許最大連接數max_connections=200# 允許連接失敗的次數。max_connect_errors=10# 服務端使用的字符集默認為UTF8character-set-server=utf8# 創建新表時將使用的默認存儲引擎default-storage-engine=INNODB# 默認使用“mysql_native_password”插件認證#mysql_native_passworddefault_authentication_plugin=mysql_native_password#關閉ONLY_FULL_GROUP_BYsql_mode= 'STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION'[mysql]# 設置mysql客戶端默認字符集default-character-set=utf8[client]# 設置mysql客戶端連接服務端時默認使用的端口port=3307default-character-set=utf8配置中標紅部分為解決問題的部分,其中注意配置需要有單引號包裹,如果你是mysql5.x,可以加上NO_AUTO_CREATE_USER;如果你是mysql8.x,則不需加上,若你加上,則會發生服務無法啟動的情況。
總結以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。
