平常使用可能發(fā)現(xiàn)不了問題,在處理大數(shù)據(jù)的時候,會發(fā)現(xiàn)內(nèi)容被截取了,其實MYSQL內(nèi)部對這個是有設(shè)置的,默認不設(shè)置的長度是1024個字符,如果我們需要更大,就需要手工去修改配置。
乾安網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)建站!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、自適應(yīng)網(wǎng)站建設(shè)等網(wǎng)站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯(lián)建站于2013年開始到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)建站。
1、查看當(dāng)前mysql group_concat_max_len
2、如果不方便重啟mysql 可以在mysql狀態(tài)通過命令設(shè)置,如
此種方式在mysql重啟后會讀取配置文件重新設(shè)置,會導(dǎo)致設(shè)置失效,所以建議依舊要修改配置文件。
3、修改配置文件:my.ini
在[mysqld]下新增配置:group_concat_max_len = 102400
重啟,通過方式1查看即可。
4、不限制大小
有時我們并不知需要多大的字節(jié)才能滿足需求,此種情況可以考慮不設(shè)置最大字節(jié)(即采用最大字節(jié)數(shù))即在配置文件設(shè)置group_concat_max_len=-1
1、導(dǎo)出用的是Hutool導(dǎo)出工具類
mysql查詢動態(tài)行轉(zhuǎn)動態(tài)列,并使用mybatis執(zhí)行
MySQL 動態(tài) 行轉(zhuǎn)列(列值轉(zhuǎn)換列名)
把tags進行分割,并和id關(guān)聯(lián)起來
結(jié)果如圖:
t_num_tmp為中間表,內(nèi)容如下:
id的最大值為 len(tags分割后tag的數(shù)量)
通過t_num_tmp中間表把t_tags的一條記錄復(fù)制為n份,n為tags分割后tag的數(shù)量。
再在這n份記錄中, 通過對應(yīng)的循環(huán)值, 取到對應(yīng)的tag
就是一個動態(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)換的表,表名不確定,作為一個參數(shù), aab001、AA011這兩個也不確定,也是參數(shù),顯示的結(jié)果把AA014這一列的內(nèi)容橫過來內(nèi)容,對應(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