A brief talk about MySQL pivot tables

A brief talk about MySQL pivot tables

I have a product parts table like this:

part

part_id part_type product_id
--------------------------------------
1A1
2 B 1
3A2
4 B 2
5A3
6 B 3

I want a query that returns a table like this:

product_id part_A_id part_B_id
----------------------------------------
1 1 2
2 3 4
3 5 6

In actual implementation, there will be millions of product parts

1 Answer

Unfortunately, MySQL doesn't have a PIVOT function, but you can model it using aggregate functions and a CASE statement. For a dynamic version you'll need to use a prepared statement:

SET @sql = NULL;
SELECT
 GROUP_CONCAT(DISTINCT
  CONCAT(
   'max(case when part_type = ''',part_type,''' then part_id end) AS part_','_id'
  )
 ) INTO @sql
FROM
 parts;
SET @sql = CONCAT('SELECT product_id,',@sql,' 
         FROM parts 
          GROUP BY product_id');
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

If you only have a few columns then you can use the static version:

select product_id,max(case when part_type ='A' then part_id end) as Part_A_Id,max(case when part_type ='B' then part_id end) as Part_B_Id
from parts
group by product_id

Summarize

The above is all the content of MySQL dynamic perspective collected and organized by 123WORDPRESS.COM for you. I hope this article can help you solve the program development problems encountered in MySQL dynamic perspective.

You may also be interested in:
  • Example code of how to implement pivot table in MySQL/MariaDB

<<:  React+TypeScript project construction case explanation

>>:  How to upgrade all Python libraries in Ubuntu 18.04 at once

Recommend

js to achieve simple drag effect

This article shares the specific code of js to ac...

MySQL database implements MMM high availability cluster architecture

concept MMM (Master-Master replication manager fo...

MySQL database backup and recovery implementation code

Database backup #grammar: # mysqldump -h server-u...

How to make a website front end elegant and attractive to users

The temperament of a web front-end website is a fe...

About Zabbix custom monitoring items and triggers

Table of contents 1. Monitoring port Relationship...

Two ways to export csv in win10 mysql

There are two ways to export csv in win10. The fi...

Summary of MySQL string interception related functions

This article introduces MySQL string interception...

What you need to know about responsive design

Responsive design is to perform corresponding ope...

A brief discussion on four solutions for Vue single page SEO

Table of contents 1.Nuxt server-side rendering ap...

Tutorial on deploying the open source project Tcloud with Docker on CentOS8

1. Install Docker 1. I installed Centos7 in the v...

Vue implements small notepad function

This article example shares the specific code of ...

Jenkins builds Docker images and pushes them to Harbor warehouse

Table of contents Dockerfile pom.xml Jenkins Conf...