Home > Database > Mysql Tutorial > Why Does My MySQL GROUP BY Query Produce a 'only_full_group_by' Error?

Why Does My MySQL GROUP BY Query Produce a 'only_full_group_by' Error?

Mary-Kate Olsen
Release: 2024-12-29 13:44:10
Original
197 people have browsed it

Why Does My MySQL GROUP BY Query Produce a

Understanding the SELECT Optimization Issue

In MySQL, when using the GROUP BY clause, it's mandatory to include all non-aggregate columns in the SELECT list that are not functionally dependent on the grouped columns. This is enforced by the sql_mode=only_full_group_by setting.

When the query:

SELECT *
FROM `tbl_customer_pod_uploads`
WHERE `load_id` = '78' AND
      `status` = 'Active'
GROUP BY `proof_type`
Copy after login

is executed, it violates this rule because the id column is not included in the GROUP BY clause. This leads to the error:

Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'returntr_prod.tbl_customer_pod_uploads.id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
Copy after login

Solution Options

To resolve this issue, there are several options:

1. Disable only_full_group_by Mode:

This can be done using the following command:

SET GLOBAL sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''));
Copy after login

However, this is not recommended as it may lead to inaccurate results.

2. Include All Columns in GROUP BY Clause:

This option ensures compliance with the only_full_group_by mode by explicitly including all non-aggregate columns in the GROUP BY clause:

SELECT *
FROM `tbl_customer_pod_uploads`
WHERE `load_id` = '78' AND
      `status` = 'Active'
GROUP BY `proof_type`, `id`
Copy after login

3. Use Aggregate Functions:

Rather than selecting specific columns, the query can utilize aggregate functions to extract data from the grouped rows, addressing the issue while adhering to best practices:

SELECT `proof_type`, COUNT(*) AS `row_count`
FROM `tbl_customer_pod_uploads`
WHERE `load_id` = '78' AND
      `status` = 'Active'
GROUP BY `proof_type`
Copy after login

This approach avoids retrieving unnecessary data and optimizes performance.

The above is the detailed content of Why Does My MySQL GROUP BY Query Produce a 'only_full_group_by' Error?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template