Rumah > pangkalan data > tutorial mysql > MySQL 用数字辅助表实现复杂的列变行

MySQL 用数字辅助表实现复杂的列变行

黄舟
Lepaskan: 2017-02-17 13:12:54
asal
1559 orang telah melayarinya

某天,QQ上一个圈子内的网友发来一个求助信息 :

PropID name   Amount
3      元宝   2
2      乐豆   3

能否用一条sql 写成输出,就是复制对应Amount 的条数 :

PropID name
3      元宝
3      元宝
2      乐豆
2      乐豆
2      乐豆

 

[注释]:

3 元宝 2
注意, 最后一列是2,就是有2条这样的记录,要变成
3 元宝
3 元宝
将最后记录条数的列去掉,直接用重复的行来表示,所以依照此例,2      乐豆   3,就要重复3条记录,如下:

2      乐豆
2      乐豆
2      乐豆

 

 

研究了下,用普通的group by sum if case when之类的搞不定,得换种思路,一时hang住了,就与网友Mr.W说起,他提供了数字辅助表的思路。

OK,搞定了,SQL如下:

select t1.propid,t1.name from tb t1,(select 1 as num union select 2 as num union select 3 as num ) t2 where t1.amount>= t2.num order by 1; 

 

中间的,(select 1 as num union select 2 as num union select 3 as num ) t2 部分

最好你另外建一个num单列辅助表表,从1自增到N,给个几万就好,然后关联查方便一些自连接的sql判断,select貌似也没循环生成数字的功能。如下表nums

 

看到这里的朋友,有更好的实现方法,请share下。

 以上就是MySQL 用数字辅助表实现复杂的列变行 的内容,更多相关内容请关注PHP中文网(www.php.cn)!


Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan