开发者

mysql8中如何设置sql-mode

目录
  • mysql8如何设置sql-uZQNOVmXwmode
  • 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
    php# 设置mysql的安装目录(你自己的目录)
    basedir="D:\\Environment\\mysql-8.0.30-winx64"
    # 设置mysql数据库的数据的存放目录
    datadir="D:\\Environment\\mysql-8http://www.devze.com.0.30-winx64\\data"
    # 允许最大连接数
    max_connections=200
    # 允许连接失败的次数。
    max_connect_errors=10
    # 服务端使用的字符集默认为UTF8
    character-set-server=utf8
    # 创建新表php时将使用的默认存储引擎
    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_EjsNGINE_SUBSTITUTION'
    [mysql]
    # 设置mysql客户端默认字符集
    default-character-set=utf8
    [client]
    # 设置mysql客户端连接服务端时默认使用的端口
    port=3307
    default-character-set=utf8

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

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

    0

    上一篇:

    下一篇:

    精彩评论

    暂无评论...
    验证码 换一张
    取 消

    最新数据库

    数据库排行榜