把tags進(jìn)行分割,并和id關(guān)聯(lián)起來
創(chuàng)新互聯(lián)建站堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)、成都外貿(mào)網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的江華網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
結(jié)果如圖:
t_num_tmp為中間表,內(nèi)容如下:
id的最大值為 len(tags分割后tag的數(shù)量)
通過t_num_tmp中間表把t_tags的一條記錄復(fù)制為n份,n為tags分割后tag的數(shù)量。
再在這n份記錄中, 通過對(duì)應(yīng)的循環(huán)值, 取到對(duì)應(yīng)的tag
平常使用可能發(fā)現(xiàn)不了問題,在處理大數(shù)據(jù)的時(shí)候,會(huì)發(fā)現(xiàn)內(nèi)容被截取了,其實(shí)MYSQL內(nèi)部對(duì)這個(gè)是有設(shè)置的,默認(rèn)不設(shè)置的長度是1024個(gè)字符,如果我們需要更大,就需要手工去修改配置。
1、查看當(dāng)前mysql group_concat_max_len
2、如果不方便重啟mysql 可以在mysql狀態(tài)通過命令設(shè)置,如
此種方式在mysql重啟后會(huì)讀取配置文件重新設(shè)置,會(huì)導(dǎo)致設(shè)置失效,所以建議依舊要修改配置文件。
3、修改配置文件:my.ini
在[mysqld]下新增配置:group_concat_max_len = 102400
重啟,通過方式1查看即可。
4、不限制大小
有時(shí)我們并不知需要多大的字節(jié)才能滿足需求,此種情況可以考慮不設(shè)置最大字節(jié)(即采用最大字節(jié)數(shù))即在配置文件設(shè)置group_concat_max_len=-1
1、導(dǎo)出用的是Hutool導(dǎo)出工具類
mysql查詢動(dòng)態(tài)行轉(zhuǎn)動(dòng)態(tài)列,并使用mybatis執(zhí)行
MySQL 動(dòng)態(tài) 行轉(zhuǎn)列(列值轉(zhuǎn)換列名)
就是一個(gè)動(dòng)態(tài)的行列轉(zhuǎn)換
CREATE TABLE `c_wssb_zz` (
`aa011` varchar(10) default NULL,
`aa001` varchar(20) default NULL,
`aa014` varchar(20) default NULL,
`aa015` varchar(200) default NULL,
`aab001` varchar(20) default NULL,
`aa010` varchar(30) default NULL,
`aae216` date default NULL,
`aa013` varchar(3) default NULL,
`aa016` varchar(10) default NULL,
`aae218` date default NULL,
`aab034` varchar(20) default NULL,
`aab901` varchar(255) default NULL
)
加入這是要轉(zhuǎn)換的表,表名不確定,作為一個(gè)參數(shù), aab001、AA011這兩個(gè)也不確定,也是參數(shù),顯示的結(jié)果把AA014這一列的內(nèi)容橫過來內(nèi)容,對(duì)應(yīng)AA015, 最后形成的數(shù)據(jù)格式如下
AAB034,AA011,AA001,AAB001,max(case when aa014='col1' then aa015 else '' end)as col1,max(case when aa014='col2' then aa015 else '' end)as col2,....max(case when aa014='colN' then aa015 else '' end)as colN,AAE216,AAE218,AA013,AA016
建表:
新增數(shù)據(jù):
源數(shù)據(jù):
行轉(zhuǎn)列后:
建表:
新增數(shù)據(jù):
源數(shù)據(jù):
列轉(zhuǎn)行后: