目录
- mysql5.7版本因为sql_mode设置导致的问题
- 尝试解决
- 方法一
- 方法二
- 关于sql_mode
- 总结
mysql5.7版本因为sql_mode设置导致的问题
因为重新安装了环境,想把之前的数据库导入到新库里面,
结果就报了如下错误:
[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”
尝试解决
方法一
登录mysql,设置sql_mode
use mysql;
set sql_mode=‘NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES';
然而并没有什么卵用
方法二
原来上边的设置方法只是会话级别的设置,真正让他生效得修改配置文件:
vi /etc/my.cnf
在[mysqld]配置项下面加上:
sql_mode=NO_UNSIGNED_SUBTRACTION,NO_ENGINE_SUBSTITUTION
重启服务,
再进入mysql
show variables like ‘sql_mode';
设置成功啦!!
关于sql_mode
官方文档:https://dev.mysql.com/doc/refman/5.7/en/sql-mode.html
重要的几项配置简单介绍,更多详细介绍移步官方文档
- NO_ENGINE_SUBSTITUTION 使用 ALTER TABLE或CREATE TABLE 指定 ENGINE 时, 需要的存储引擎被禁用或未编译,该如何处理。
- 启用NO_ENGINE_SUBSTITUTION时,那么直接抛出错误;不设置此值时,CREATE用默认的存储引擎替代,ATLER不进行更改,并抛出一个 warning .
- STRICT_TRANS_TABLES 设置它,表示启用严格模式。
注意: STRICT_TRANS_TABLES 不是几种策略的组合,单独指 INSERT、UPDATE出现少值或无效值该如何处理:
- 例如:
如果我们建表的时候不严格,比如字段设置是NOT NULL,然而并没有给字段设置默认值,在插入语句的时候,这个字段我们忽略,没有赋值,恰好这个时候mysql的sql_mode是严格模式,即启用了STRICT_TRANS_TABLES,就会报字段没有默认值的错误。
或者说,我们将空字符串赋值给int类型的字段,在严格模式下也会报同样的错误。如果sql_mode没有配置STRICT_TRANS_TABLES则不会报错
ONLY_FULL_GROUP_BY 对于GROUP BY聚合操作,如果在SELECT中的列、HAVING或者ORDER BY子句的列,没有在GROUP BY中出现,那么这个SQL是不合法的。因为不在 group by 的列查出来展示会有矛盾。
- 例如:
SELECT id from conf_merchant GROUP BY merchant_id;
这条sql在ONLY_FULL_GROUP_BY模式下就会报错。
1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column ‘iapw.conf_merchant.market_id’ which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
如果sql_mode 没有配置ONLY_FULL_GROUP_BY,就不会报错。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网(www.lsjlt.com)。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
软考中级精品资料免费领
- 历年真题答案解析
- 备考技巧名师总结
- 高频考点精准押题
- 资料下载
- 历年真题
193.9 KB下载数265
191.63 KB下载数245
143.91 KB下载数1148
183.71 KB下载数642
644.84 KB下载数2756
相关文章
发现更多好内容- 在 Java 中如何通过反射获取字段的值?(java中怎么通过反射获取字段的值)
- 如何在 Java 中创建类的实例对象?(java怎么创建类的实例对象)
- 如何高效更新Uncomtrade数据库数据
- 如何在 Java 中获取端口数据?(java怎么获取端口数据)
- 如何在 Java 中实现异步处理?(java怎么实现异步处理)
- Java 写小程序都用到了哪些技术呢?(java写小程序用到的技术有哪些)
- Java 动态数据源切换的方法究竟有哪些?(java动态数据源切换的方法是什么)
- JavaScript函数式编程的亮点有哪些?(JavaScript函数式编程有啥亮点)
- 如何保障 Java 应用程序的安全性?(Java应用程序的安全性如何保障)
- Java 中 aspect 关键字的作用范围是怎样的?(java aspect关键字的作用范围)