建表:

成都創(chuàng)新互聯(lián)長期為成百上千家客戶提供的網(wǎng)站建設(shè)服務(wù),團隊從業(yè)經(jīng)驗10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為皋蘭企業(yè)提供專業(yè)的成都網(wǎng)站建設(shè)、網(wǎng)站制作,皋蘭網(wǎng)站改版等技術(shù)服務(wù)。擁有10年豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。
新增數(shù)據(jù):
源數(shù)據(jù):
行轉(zhuǎn)列后:
建表:
新增數(shù)據(jù):
源數(shù)據(jù):
列轉(zhuǎn)行后:
就是一個動態(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
平常使用可能發(fā)現(xiàn)不了問題,在處理大數(shù)據(jù)的時候,會發(fā)現(xiàn)內(nèi)容被截取了,其實MYSQL內(nèi)部對這個是有設(shè)置的,默認不設(shè)置的長度是1024個字符,如果我們需要更大,就需要手工去修改配置。
1、查看當前mysql group_concat_max_len
2、如果不方便重啟mysql 可以在mysql狀態(tài)通過命令設(shè)置,如
此種方式在mysql重啟后會讀取配置文件重新設(shè)置,會導致設(shè)置失效,所以建議依舊要修改配置文件。
3、修改配置文件:my.ini
在[mysqld]下新增配置:group_concat_max_len = 102400
重啟,通過方式1查看即可。
4、不限制大小
有時我們并不知需要多大的字節(jié)才能滿足需求,此種情況可以考慮不設(shè)置最大字節(jié)(即采用最大字節(jié)數(shù))即在配置文件設(shè)置group_concat_max_len=-1
1、導出用的是Hutool導出工具類
mysql查詢動態(tài)行轉(zhuǎn)動態(tài)列,并使用mybatis執(zhí)行
MySQL 動態(tài) 行轉(zhuǎn)列(列值轉(zhuǎn)換列名)
復盤一下前兩天MySQL的一道筆試題。
建表語句為:
這是典型的行轉(zhuǎn)列操作。方法有以下兩種:
注意:max() 是為了能夠使用 group by 根據(jù) id 進行分組,因為每一個 id 對應(yīng)的course = '語文' 的記錄只有一條,所以 max() 的值就等于對應(yīng)那一條記錄的 score 的值。 因此sum()、min()、avg()等聚合函數(shù)都可以達到行轉(zhuǎn)列的效果。
若要實現(xiàn)對每一列也求和,可以使用with rollup直接生成結(jié)果。
文章題目:mysql怎么進行轉(zhuǎn)列,MySQL 行轉(zhuǎn)列
瀏覽地址:http://chinadenli.net/article37/dsiessj.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、定制網(wǎng)站、品牌網(wǎng)站設(shè)計、手機網(wǎng)站建設(shè)、微信公眾號、關(guān)鍵詞優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)