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:
|
<<: React+TypeScript project construction case explanation
>>: How to upgrade all Python libraries in Ubuntu 18.04 at once
This article shares the specific code of js to ac...
concept MMM (Master-Master replication manager fo...
Table of contents 1. Install vmware 1.1 Download ...
Database backup #grammar: # mysqldump -h server-u...
The temperament of a web front-end website is a fe...
Table of contents 1. Monitoring port Relationship...
There are two ways to export csv in win10. The fi...
This article introduces MySQL string interception...
Responsive design is to perform corresponding ope...
Table of contents 1.Nuxt server-side rendering ap...
They are all web page templates from the foreign ...
1. Install Docker 1. I installed Centos7 in the v...
Preface The concept of dark mode originated from ...
This article example shares the specific code of ...
Table of contents Dockerfile pom.xml Jenkins Conf...