Detailed explanation of count(), group by, order by in MySQL

Detailed explanation of count(), group by, order by in MySQL

I recently encountered a problem when doing IM, and used these three keywords at the same time. It is to query the offline message details of a person. The details returned by our server to the client include three contents. The first one requires to list which people or groups have sent you messages during the offline period. The second one is how many offline messages a certain person or group has sent. The third one is to display the latest one. Obviously, group by groups which people or groups have sent you offline messages, count() gets the number of offline messages, and order by time sorts to get the latest messages.

select count(1) as cnt, msg_data from t_im_chat_offline_msg where to_company_id = ? and to_user_id = ? order by create_time desc group by from_company_id, from_user_id;

Then, as expected, an error occurs when searching with group by and order by together. We can use nested subqueries.

select count(1) as cnt, msg_data from (select * from t_im_chat_offline_msg where to_company_id = ? and to_user_id = ? order by create_time desc) as temp_table group by from_company_id, from_user_id;

We can group and calculate the number of results that have already been sorted. There is a hidden pit here, which I accidentally avoided. In fact, count() will cause the order by sort to be invalid. For example:

select count(1) as cnt, msg_data from t_im_chat_offline_msg where to_company_id = ? and to_user_id = ? order by create_time desc;

The statement finally obtains a record in which msg_data is actually not sorted at all, that is, the original order of the database. It should be the message that was inserted first, that is, the old message. To avoid this problem, the nested subquery is sorted first and then count() is used to avoid it. I dodged it unintentionally, but I discovered it after I modified the sentence and tested it again and again.

You may also be interested in:
  • Usage and performance optimization techniques of aggregate function count in MySQL
  • MySQL count detailed explanation and function example code
  • Detailed explanation of the usage of the COUNT function in MySQL
  • A brief discussion on MySQL count of rows
  • Summary of methods to improve mysql count
  • Detailed explanation of count without filter conditions in MySQL
  • Summary of the differences between count(*), count(1) and count(col) in MySQL
  • Comparison of usage of distinct and count(*) in MySQL
  • A convenient way to count the total number of rows in MYSQL query results without counting (*)
  • Explanation and usage of found_row() and row_count() in MySQL
  • Detailed explanation of the correct use of the count function in MySQL

<<:  WeChat applet to achieve the revolving lantern effect example

>>:  A complete example of Vue's multi-level jump (page drill-down) function for related pages

Recommend

MySQL data operation-use of DML statements

illustrate DML (Data Manipulation Language) refer...

React realizes secondary linkage (left and right linkage)

This article shares the specific code of React to...

Installation and configuration method of vue-route routing management

introduce Vue Router is the official routing mana...

Linux tac command implementation example

1. Command Introduction The tac (reverse order of...

Detailed explanation of Vue development website SEO optimization method

Because the data binding mechanism of Vue and oth...

Nginx monitoring issues under Linux

nginx installation Ensure that the virtual machin...

How to import/save/load/delete images locally in Docker

1. Docker imports local images Sometimes we copy ...

Solution to incomplete text display in el-tree

Table of contents Method 1: The simplest way to s...

Detailed steps to configure MySQL remote connection under Alibaba Cloud

Preface As we all know, by default, the MySQL ins...

Analysis of JavaScript's event loop mechanism

Table of contents Preface: 1. Reasons for the eve...

MySql learning day03: connection and query details between data tables

Primary Key: Keyword: primary key Features: canno...

React implements infinite loop scrolling information

This article shares the specific code of react to...