• sql查询出现1055 this is incompatible with sql_mode=only_full_group_by


    今天在测试服务器上突然出现了这么一个MySQL的问题,同样的代码正式服没有问题,那肯定就是出在了配置上,查了一下原因才明白原来是数据库版本为5.7以上的版本,

    默认是开启了 only_full_group_by 模式的,但开启这个模式后,原先的 group by 语句就报错,

    查询MySQL版本可以在命令行模式刚连接上数据库时就能看到,或者在进入mysql后使用命令:status查看版本号,

    既然是版本的问题,那就查询一下配置看看具体的情况,命令行连接上数据库,再输入命令:

    select @@sql_mode;

    你会看到sql_mode的配置情况:

    其中ONLY_FULL_GROUP_BY就是造成这个错误的罪魁祸首了,

    对于group by聚合操作,如果在select中的列没有在group by中出现,那么这个SQL是不合法的,因为列不在group by从句中,所以设置了sql_mode=only_full_group_by的数据库,在使用group by时就会报错,

    既然知道了问题,那么修改这个配置就可以了,找到MySQL的配置文件,在linux系统上/etc/my.cnf文件,查询sql_mode字段,我并没有在配置文件中找到这个关键字,所以我手动添加进去:

    sql_mode = STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

    需要注意的一点是一定要添加在[mysqld]配置内,这样添加完后重启mysql才会生效,退出数据库:exit,重启命令:

    service mysqld restart;

    刷新页面报错信息消失成功解决,再次连接上数据库查看sql_mode配置select @@sql_mode:

    到此已经成功解决了这个问题。

    转自 郑帅杰博客https://www.cnblogs.com/52lnamp

  • 相关阅读:
    KindEditor
    JS缺失错误- Uncaught SyntaxError: Unexpected token <
    JS
    SQL
    Bootstrap
    CSS-筛选 获取第一个td
    订单号创建并发问题
    保存对象时碰到的问题-列名 'Discriminator' 无效
    ViewBag对象的更改
    Kafka协议兼容性改进
  • 原文地址:https://www.cnblogs.com/sanduweiliangxtx/p/12024278.html
Copyright © 2020-2023  润新知