2

我的项目中配置了两个数据库,一个在我的本地机器上运行,另一个在远程服务器上运行。我访问远程数据库服务器没有任何问题,但在访问本地 MySQL 数据库时出现以下错误。

 WARN  [org.hibernate.util.JDBCExceptionReporter] SQL Error: 1140, SQLState: 42000
 ERROR [org.hibernate.util.JDBCExceptionReporter] Mixing of GROUP columns (MIN(),MAX(),COUNT(),...) with no GROUP columns is illegal if there is no GROUP BY clause

我看到了 MySQL 文档,但无法完全理解根本原因。我认为,因为我可以从远程数据库中获取相同的数据,所以java code and query是正确的。

4

2 回答 2

2

以下查询在ONLY_FULL_GROUP_BY启用时无效。第一个无效,因为选择列表中的名称未在GROUP BY子句中命名

mysql> SELECT name, MAX(age) FROM t;
ERROR 1140 (42000): Mixing of GROUP columns (MIN(),MAX(),COUNT(),...)

如果没有 GROUP BY 子句,则没有 GROUP 列是非法的

您可以重新编写查询以正常工作

mysql> SELECT name, MAX(age) FROM t GROUP BY name;

或者

关闭ONLY_FULL_GROUP_BY,错误应该会消失。

链接可以帮助你

  1. 您可以在此处搜索 MySQL 错误
  2. 按功能分组
  3. stackoverflow.com 上的类似帖子
  4. 另一个讨论类似问题的论坛
  5. 服务器-sql-模式

更新

这是对您评论的回答。

But i would like to know more about disabling the Group BY mode in mysql db.  

服务器 SQL 模式

  • MySQL 服务器可以在不同的 SQL 模式下运行,并且可以针对不同的客户端以不同的方式应用这些模式,具体取决于sql_mode系统变量的值。此功能使每个应用程序都可以根据自己的要求调整服务器的操作模式。

  • 要在服务器启动时设置 SQL 模式,请使用--sql-mode="modes"命令行上的选项,或sql-mode="modes"在选项文件中,例如my.cnf (Unix operating systems)my.ini (Windows)。模式是用逗号分隔的不同模式的列表。要明确清除 SQL 模式,请--sql-mode=""在命令行或sql-mode=""选项文件中使用将其设置为空字符串。

  • 要在运行时更改 SQL 模式,请使用

    SET [GLOBAL|SESSION] sql_mode='modes'
    语句来设置 sql_mode 系统变量。设置GLOBAL 变量需要 SUPER 权限并影响从那时起连接的所有客户端的操作。设置 SESSION 变量仅影响当前客户端。任何客户端都可以随时更改自己的会话 sql_mode 值。

  • 要确定当前的全局或会话 sql_mode 值,请使用以下语句:

    SELECT @@GLOBAL.sql_mode;
    SELECT @@SESSION.sql_mode;

  • 您可以参考sql_mode 表


I followed the manuals, Added the ONLY_FULL_GROUP_BY in sql-mode
but no difference.  

发生这种情况是因为 MySQL 版本。您本地计算机的 MySQL 版本是多少?

如何查看 MySQL 版本?

mysql> SELECT version();
+-----------+
| version() |
+-----------+
| 5.5.28    |
+-----------+
1 row in set (0.00 sec)    

为了测试 sql_mode ONLY_FULL_GROUP_BY,我创建了patient包含两列id, name并插入记录的表。请记住 sql_modeONLY_FULL_GROUP_BY不是默认设置,如果需要,您需要设置。

1)MySQL 版本5.0.45-community-nt

SELECT name, MAX(id) FROM patient;
ERROR 1140 (42000): Mixing of GROUP columns (MIN(),MAX(),COUNT(),...) with no GROUP columns is illegal if there is no GROUP BY clause  

它失败了,将 sql_mode 设置为没有意义,ONLY_FULL_GROUP_BY因为它不允许未在 GROUP BY 子句中命名的非聚合列。

2)MySQL 5.1.40 版-社区

mysql> SELECT name, MAX(id) from patient;
+----------+--------+
| MAX(id)  | name   |
+----------+--------+
|       33 | aniket |
+----------+--------+
1 row in set (0.03 sec)  

然后设置sql_mode后ONLY_FULL_GROUP_BY

mysql> set sql_mode = 'ONLY_FULL_GROUP_BY';
Query OK, 0 rows affected (0.00 sec)

mysql> SELECT name, MAX(id) from patient;
ERROR 1140 (42000): Mixing of GROUP columns (MIN(),MAX(),COUNT(),...) with no GROUP columns is illegal if there is no GROUP BY clause  

3)MySQL 版本5.5.28

mysql> SELECT name, MAX(id) from patient;
+----------+--------+
| MAX(id)  | name   |
+----------+--------+
|       33 | aniket |
+----------+--------+
1 row in set (0.03 sec)  

然后设置sql_mode后ONLY_FULL_GROUP_BY

mysql> set sql_mode = 'ONLY_FULL_GROUP_BY';
Query OK, 0 rows affected (0.00 sec)

mysql> SELECT name, MAX(id) from patient;
ERROR 1140 (42000): Mixing of GROUP columns (MIN(),MAX(),COUNT(),...) with no GROUP columns is illegal if there is no GROUP BY clause  

结论

如您所见,查询在 5.0.45 版本上失败,并且在 5.1.40 和 5.5.28 上/之后成功 在 MySQL 5.1.10 版本之前(不确定)查询没有GROUP BY失败,无论是否设置了 sql_mode ONLY_FULL_GROUP_BY

一些有趣的错误和 sql_mode 常见问题链接

  1. ONLY_FULL_GROUP_BY sql模式过于严格
  2. sql-mode:只有完整的 group by 模式不起作用
  3. MySQL 5.0 FAQ:服务器 SQL 模式
于 2013-10-10T13:51:54.703 回答
0

您需要包含一个GROUP BY子句(您没有发布您的查询,但我猜您根据错误缺少一个子句)。这只是您的本地主机而不是远程服务器的问题的原因是远程服务器可能关闭了ONLY_FULL_GROUP_BY但您的本地数据库已打开它。

理想情况下,您应该指定一个GROUP BY子句,但您也可以只切换本地数据库的 ONLY_FULL_GROUP_BY 设置。

于 2013-10-10T13:35:42.463 回答