1:修改数据库配置(重启失效)

select @@global.sql_mode;

会打印如下信息

ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION

里面包含 ONLY_FULL_GROUP_BY,那么就重新设置,在数据库输入以下代码,去掉ONLY_FULL_GROUP_BY即可

SET GLOBAL sql_mode='STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION';

2:修改mysql配置文件永久生效修改后重启,即可生效

修改配置文件my.ini ,在[mysqld]模块下新增一行配置

sql_mode='STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION';

3:存储过程test_procedure_group_by,执行存储过程报错

4:查看存储过程的sql_mode

select routine_catalog,routine_schema,routine_name,routine_type,created,last_altered,sql_mode from information_schema.routines where routine_name='test_procedure_group_by';

在这里插入图片描述

5:解决办法简单,重建该存储过程即可,即使每次执行都先删除创建

drop procedure test_for_group_by;

修改sql_mode系统变量,只对新建连接新建对象(主要包括函数存储过程)有效,对已有连接和已有对象生效

可以先通过代码sql删除存储过程然后调用存储过程

原文地址:https://blog.csdn.net/qq_19891197/article/details/134696272

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_9266.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注