MySQL implements multi-table association statistics (subquery statistics) example

MySQL implements multi-table association statistics (subquery statistics) example

This article uses an example to describe how to implement multi-table association statistics in MySQL. Share with you for your reference, the details are as follows:

need:

Statistics on the reward amount for each book, recharge data statistics at different times, consumption statistics,

Design four tables, book table, orders table, reward_log table, consume_log table, and associate them with book table through book_id.

question:

When more than two tables are associated, data duplication occurs during statistics. You have to use a subquery to find it out. A subquery can only query one field. Here, the CONCAT_WS function is used to concatenate multiple fields.

accomplish:

The query code is as follows

SELECT
b.id,
b.book_name,
sum( IF ( o.create_time > 0 && o.create_time < 9999999999, o.price, 0 ) ) today_pay_money,
sum( IF ( o.create_time > 0 && o.create_time < 9999999999, 1, 0 ) ) today_pay_num,
sum( IF ( o.create_time > 999 && o.create_time < 9999, o.price, 0 ) ) yesterday_pay_money,
sum( IF ( o.create_time > 999 && o.create_time < 9999, 1, 0 ) ) yesterday_pay_num,
sum(o.price) total_pay_money,
sum( IF ( o.create_time > 9999 && o.create_time < 99999, 1, 0 ) ) total_pay_num,
( SELECT SUM( total_score ) FROM book_reward_log WHERE book_id = b.id ) total_score,
(
 SELECT
 CONCAT_WS(
  ',',
  SUM( IF ( create_time > 0 && create_time < 998, score, 0 ) ),
  SUM( IF ( create_time > 9999 && create_time < 99998, score, 0 ) ),
  SUM( IF ( create_time > 99999 && create_time < 999998, score, 0 ) )
 )
 FROM
 book_consume_log
 WHERE
 book_id = b.id
 ) score
 FROM
 book_book b
 LEFT JOIN book_orders o ON b.id = o.bid
GROUP BY
 b.id

Query results

score is three consumption numbers, separated by commas

Performance Analysis

Readers who are interested in more MySQL-related content can check out the following topics on this site: "MySQL query skills", "MySQL common functions summary", "MySQL log operation skills", "MySQL transaction operation skills summary", "MySQL stored procedure skills" and "MySQL database lock related skills summary"

I hope this article will be helpful to everyone's MySQL database design.

You may also be interested in:
  • Example of how to retrieve the latest data using MySQL multi-table association one-to-many query
  • A brief discussion on the implementation of multi-table unrelated query in MySQL
  • MySQL detailed explanation of multi-table association query

<<:  Let’s talk in detail about how JavaScript affects DOM tree construction

>>:  Diagram of the process of implementing direction proxy through nginx

Recommend

Mysql backup multiple database code examples

This article mainly introduces the Mysql backup m...

Example code of vue custom component to implement v-model two-way binding data

In the project, you will encounter custom public ...

A few experiences in self-cultivation of artists

As the company's influence grows and its prod...

Using group by in MySQL always results in error 1055 (recommended)

Because using group by in MySQL always results in...

Mac installation mysqlclient process analysis

Try installing via pip in a virtual environment: ...

Implementation example of Docker rocketmq deployment

Table of contents Preparation Deployment process ...

How to change password and set password complexity policy in Ubuntu

1. Change password 1. Modify the password of ordi...

JavaScript macrotasks and microtasks

Macrotasks and Microtasks JavaScript is a single-...

MySQL optimization solution: enable slow query log

Table of contents Preface Setting up slow query l...

Detailed explanation of the construction and use of Docker private warehouse

The image can be saved on hub.docker.com, but the...

How to delete extra kernels in Ubuntu

Step 1: View the current kernel rew $ uname -a Li...

Vue3 encapsulates the side navigation text skeleton effect component

Vue3 project encapsulation side navigation text s...

How to write HTML head in mobile device web development

Copy code The code is as follows: <head> &l...