Solve the grouping error Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated in MySQL versions greater than 5.7

Solve the grouping error Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated in MySQL versions greater than 5.7

reason:

MySQL 5.7.5 and up implements detection of functional dependencies. If the only_full_group_by SQL mode is enabled (which it is by default), MySQL rejects queries whose select lists, conditions, or order lists refer to nonaggregate columns that are not named in the group by without being functionally dependent on them. (Prior to 5.7.5, MySQL did not detect feature dependencies and only_full_group_by was not enabled by default. See the MySQL 5.6 Reference Manual for a description of the pre-5.7.5 behavior.)

Execute the following command to view the content of sql_mode:

mysql> SHOW SESSION VARIABLES;
mysql> SHOW GLOBAL VARIABLES;
mysql> select @@sql_mode;

It can be seen that the values ​​of sql_mode for session and global are:

ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

only_full_group_by description:

only_full_group_by: This option uses the same group rules as Oracle. The selected columns must be in the group or be aggregate columns (SUM, AVG, MAX, MIN). In fact, I personally feel that this configuration is similar to distinct, so just remove it.

solve:

set global sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';<br data-filtered="filtered">set session sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';<br data-filtered="filtered">

Summarize

The above is the solution to the grouping error Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated in MySQL version greater than 5.7. I hope it will be helpful to you. If you have any questions, please leave me a message and I will reply to you in time. I would also like to thank everyone for their support of the 123WORDPRESS.COM website!
If you find this article helpful, please feel free to reprint it and please indicate the source. Thank you!

You may also be interested in:
  • MySQL group by method for single word grouping sequence and multi-field grouping
  • MySql Group By implements grouping of multiple fields
  • Mysql uses group by group sorting
  • How to use GROUP BY in MySQL to get the first N records
  • Detailed explanation of the implementation principle of MySQL group query Group By
  • MySQL grouping to get the first few records in each group (ranking) with research on group by and order by
  • Implement group by based on MySQL to get the latest data of each group

<<:  Detailed explanation of nginx forward proxy and reverse proxy

>>:  JS implements the rock-paper-scissors game

Recommend

Analysis of the process of simply deploying nginx in Docker container

1. Deploy nginx service in container The centos:7...

Realize the CSS loading effect after clicking the button

Since there is a button in my company's produ...

Detailed steps for building Portainer visual interface with Docker

In order to solve the problem mentioned last time...

How to install Docker on Windows 10 Home Edition

I recently used Docker to upgrade a project. I ha...

How to recover accidentally deleted table data in MySQL (must read)

If there is a backup, it is very simple. You only...

Tips for using top command in Linux

First, let me introduce the meaning of some field...

Advantages and disadvantages of Table layout and why it is not recommended

Disadvantages of Tables 1. Table takes up more byt...

JavaScript super detailed implementation of web page carousel

Table of contents Creating HTML Pages Implement t...

Detailed explanation of the practical application of centos7 esxi6.7 template

1. Create a centos7.6 system and optimize the sys...

Comparison between Redis and Memcache and how to choose

I've been using redis recently and I find it ...

JavaScript implements double-ended queue

This article example shares the specific code of ...

The best explanation of HTTPS

Good morning everyone, I haven’t updated my artic...

How to draw a mind map in a mini program

Table of contents What is a mind map? How to draw...

CSS to achieve particle dynamic button effect

Original link https://github.com/XboxYan/no… A bu...

The difference and usage between div and span

Table of contents 1. Differences and characterist...