Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > MySQL 1055错误解决

MySQL出现1055错误:ONLY_FULL_GROUP_BY的问题解决

作者:一勺菠萝丶

当你执行SQL查询时突然遇到"1055 - Expression #1 of SELECT list is not in GROUP BY clause…"错误,该怎么办呢,下面小编就来和大家简单讲讲吧

当你执行SQL查询时突然遇到"1055 - Expression #1 of SELECT list is not in GROUP BY clause…"错误,是不是一脸懵?别担心!这篇文章将用最简单的语言解释这个MySQL 8.0常见错误的原因和解决方案,即使你是SQL小白也能轻松搞定!

错误重现:典型的报错场景

SELECT
  product_id,
  product_name,
  pic,
  sp_data,
  SUM(quantity) AS total_sales
FROM order_items
GROUP BY sku_id;  -- 这里只按sku_id分组

错误信息:

1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'ry-mall.item.product_id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

一、错误原因解析(小学生也能懂!)

想象你有一盒彩色铅笔(数据库表),里面有:

现在老板要求:“按铅笔型号分组,统计每种型号的总数量,同时显示颜色、批次和图片”

问题来了:

核心原因:SELECT中的列(如product_name)没有出现在GROUP BY中,MySQL无法确定取哪个值

二、3种解决方案(附详细示例)

方案1:完善GROUP BY子句(推荐⭐️⭐️⭐️⭐️⭐️)

SELECT
  product_id,
  product_name,
  pic,
  sp_data,
  SUM(quantity) AS total_sales
FROM order_items
GROUP BY 
  sku_id,          -- 原始分组列
  product_id,      -- 新增
  product_name,    -- 新增
  pic,             -- 新增
  sp_data          -- 新增

优点:

缺点:

GROUP BY列表较长

方案2:使用聚合函数(高效方案⭐️⭐️⭐️⭐️)

SELECT
  MAX(product_id) AS product_id,      -- 使用MAX取值
  MAX(product_name) AS product_name,  -- 使用MAX取值
  MAX(pic) AS pic,
  MAX(sp_data) AS sp_data,
  SUM(quantity) AS total_sales
FROM order_items
GROUP BY sku_id  -- 只需分组一列

适用场景:

重要提示:

方案3:临时关闭严格模式(应急方案⭐️)

-- 第一步:查看当前模式
SELECT @@sql_mode;

-- 第二步:移除ONLY_FULL_GROUP_BY
SET SESSION sql_mode = 'STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';

-- 第三步:执行原SQL
SELECT ... (原始问题语句)

强烈不推荐:

三、原问题SQL修复完整版

SELECT
  item.product_id,
  item.product_name,
  item.pic,
  item.sp_data,
  SUM(item.quantity) AS total_sales  -- 去掉IFNULL更简洁
FROM oms_order_item item
INNER JOIN oms_order o ON o.id = item.order_id  -- 改用INNER JOIN
WHERE o.STATUS IN (1, 2, 3)
  AND item.create_time >= '2025-07-28 00:00:00'
  AND item.create_time < '2025-07-29 00:00:00'
GROUP BY 
  item.sku_id,
  item.product_id,     -- 关键修复!
  item.product_name,   -- 关键修复!
  item.pic,            -- 关键修复!
  item.sp_data         -- 关键修复!
ORDER BY total_sales DESC
LIMIT 10;

四、预防措施 & 最佳实践

1.设计表结构时:

-- 确保sku_id能唯一确定商品信息
ALTER TABLE products ADD UNIQUE (sku_id);

2.永久修改sql_mode(慎重!):

-- 编辑MySQL配置文件 my.cnf:
[mysqld]
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION

3.开发规范:

所有SELECT的非聚合列必须出现在GROUP BY中

使用别名时特别注意:

SELECT 
  product_id AS id,  -- 别名
  ...
GROUP BY product_id  -- 必须用原始列名!

总结:选择哪种方案?

情况推荐方案原因
生产环境方案1(完善GROUP BY)数据绝对安全
测试环境方案2(使用MAX)执行更快
紧急调试方案3(关闭严格模式)快速验证

记住这个黄金法则:GROUP BY中的列,应该能唯一确定SELECT中的其他列。遵循这个原则,你将永远告别1055错误!

到此这篇关于MySQL出现1055错误:ONLY_FULL_GROUP_BY的问题解决的文章就介绍到这了,更多相关MySQL 1055错误解决内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文