mysql8中如何设置sql-mode

2023-12-07 0 651
目录
  • mysql8如何设置sql-mode
  • mysql8配置sql_mode(解决group by遇到的Expression #2 of SELECT list is not in GROUP BY clause问题)
    • 问题
    • 解决方法一(不推荐):sql设置
    • 解决方法二:修改Mysql的默认配置文件my.ini(推荐)
  • 总结

    mysql8如何设置sql-mode

    mysql8报错,

    mysql8中如何设置sql-mode

    在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\’

    mysql8中如何设置sql-mode

    在mysqlld下添加sql-mode

    mysql8中如何设置sql-mode

    mysql8配置sql_mode(解决group by遇到的Expression #2 of SELECT list is not in GROUP BY clause问题)

    问题

    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
    # 服务端使用的字符集默认为UTF8
    character-set-server=utf8
    # 创建新表时将使用的默认存储引擎
    default-storage-engine=INNODB
    # 默认使用“mysql_native_password”插件认证
    #mysql_native_password
    default_authentication_plugin=mysql_native_password
    #关闭ONLY_FULL_GROUP_BY
    sql_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=3307
    default-character-set=utf8

    配置中标红部分为解决问题的部分,其中注意配置需要有单引号包裹,如果你是mysql5.x,可以加上NO_AUTO_CREATE_USER;如果你是mysql8.x,则不需加上,若你加上,则会发生服务无法启动的情况。

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持悠久资源网。

    收藏 (0) 打赏

    感谢您的支持,我会继续努力的!

    打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
    点赞 (0)

    悠久资源 Mysql mysql8中如何设置sql-mode https://www.u-9.cn/database/mysql/121385.html

    常见问题

    相关文章

    发表评论
    暂无评论
    官方客服团队

    为您解决烦忧 - 24小时在线 专业服务