In Mysql, batch add multiple columns to table based on another column
P粉336536706
2023-08-28 11:03:44
<p>I have a table with three columns.
For each id, we have up to 400 <code>index</code> values. I want to add columns based on the number of index. In the example I provided, I have 4 indexes and then I added four columns to the table. This is the table I have: </p>
<pre class="brush:php;toolbar:false;">Create table buy_sell (id int, idx varchar(255), sell float(2, 1));
insert into buy_sell (id, idx, sell) values ('1', 'a', '4');
insert into buy_sell (id, idx, sell) values ('1', 'b', '6');
insert into buy_sell (id, idx, sell) values ('1', 'c', '8');
insert into buy_sell (id, idx, sell) values ('1', 'd', '9');
insert into buy_sell (id, idx, sell) values ('3', 'b ', '1');
insert into buy_sell (id, idx, sell) values ('3', 'c ', '2');
insert into buy_sell (id, idx, sell) values ('2', 'a', '5');
insert into buy_sell (id, idx, sell) values ('2', 'b', '7');
insert into buy_sell (id, idx, sell) values ('2', 'd', '5');
SELECT * FROM buy_sell;</pre>
<p>This is the result: </p>
<table class="s-table">
<thead>
<tr>
<th>id</th>
<th>idx</th>
<th>For Sale</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>a</td>
<td>4.0</td>
</tr>
<tr>
<td>1</td>
<td>b</td>
<td>6.0</td>
</tr>
<tr>
<td>1</td>
<td>c</td>
<td>8.0</td>
</tr>
<tr>
<td>1</td>
<td>d</td>
<td>9.0</td>
</tr>
<tr>
<td>3</td>
<td>b</td>
<td>1.0</td>
</tr>
<tr>
<td>3</td>
<td>c</td>
<td>2.0</td>
</tr>
<tr>
<td>2</td>
<td>a</td>
<td>5.0</td>
</tr>
<tr>
<td>2</td>
<td>b</td>
<td>7.0</td>
</tr>
<tr>
<td>2</td>
<td>d</td>
<td>5.0</td>
</tr>
</tbody>
</table>
<p>For example, for id=1, we have four indexes here (a, b, c, d), and then we have four non-zero columns.For id = 3 we have two indexes (b, c) and then we have two non-zero columns, so for the first column we put zero, for the second column we put 1 and for the third column we Place 2. So on and so forth. This is the table I want: </p>
<table class="s-table">
<thead>
<tr>
<th>id</th>
<th>Sell 1</th>
<th>Sell 2</th>
<th>Sell 3</th>
<th>Sell 4</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>4</td>
<td>6</td>
<td>8</td>
<td>9</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>1</td>
<td>2</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>5</td>
<td>7</td>
<td>0</td>
<td>5</td>
</tr>
</tbody>
</table>
<p>I searched a lot and tried <code>Group_concat</code>, <code>JSON_ARRAYAGG</code> etc. but I couldn't find a solution. what do I need to do? </p>
The SQL language has very strict requirements for knowing the number of columns in the result at query compile time, before any data is viewed. If you have to look at the data to determine the number of columns you want, then you can only use (potentially dangerous) dynamic SQL, which requires three steps:
In this case, you don't know how many columns are required, only that it is "up to 400 columns". With this in mind, you might see code like this:
Yes, you do need to specify something in the query for every possible column. This also assumes that your
sell
values are all greater than 0. If your values are likely to be a mix of positive and negative numbers, you might try usingSUM()
instead ofMAX()
.This approach is also directly contrary to the set theory principles behind relational databases, so in practice you are better off letting client code or reporting tools do the pivoting on the data.