把tags進(jìn)行分割,并和id關(guān)聯(lián)起來(lái)

創(chuàng)新互聯(lián)專注于東至企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè)公司,成都商城網(wǎng)站開發(fā)。東至網(wǎng)站建設(shè)公司,為東至等地區(qū)提供建站服務(wù)。全流程定制網(wǎng)站,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)
結(jié)果如圖:
t_num_tmp為中間表,內(nèi)容如下:
id的最大值為 len(tags分割后tag的數(shù)量)
通過(guò)t_num_tmp中間表把t_tags的一條記錄復(fù)制為n份,n為tags分割后tag的數(shù)量。
再在這n份記錄中, 通過(guò)對(duì)應(yīng)的循環(huán)值, 取到對(duì)應(yīng)的tag
你好!
你寫的確實(shí)有點(diǎn)復(fù)雜!
你可以分兩步:
1 . 獲取每個(gè)人每個(gè)學(xué)科的最新考試成績(jī)
select?b.name,b.class,b.score?from?score?b,
(select?a.name,a.class,max(a.time)?tims?from?score?a?group?by?a.name,a.class)?a
where?b.name?=?a.name
and?a.class?=?b.class
and?a.tims?=?b.time;
2 . 進(jìn)行行專列操作
對(duì)上面的數(shù)據(jù)進(jìn)行行列轉(zhuǎn)化操作,比較常見了!
歡迎追問,望采納
試下這個(gè):
select etimattendancelistid,
max(case when etimkaoqinfanwei='上午上班' then etimkaoqinzhuangtai else '' end) As '上午上班',
max(case when etimkaoqinfanwei='下午上班' then etimkaoqinzhuangtai else '' end) As '下午上班'
From kaoqin group By etimattendancelistid
case when就可以完成行轉(zhuǎn)列
select case id when 'inspectiondate' then '2016-07-26' when 'qiangxiandate' then '2016-12-28' when 'shangyexiandate' then '2016-05-04' else '' end
from 表名。。。。
1、首先,使用case when函數(shù)輸出單個(gè)課程的成績(jī)
case when course='語(yǔ)文' then score end as 語(yǔ)文case when course='數(shù)學(xué)' then score end as 數(shù)學(xué)case when course='英語(yǔ)' then score end as 英語(yǔ)
sql語(yǔ)句:
select name ,case when course='語(yǔ)文' then score end as 語(yǔ)文,case when course='數(shù)學(xué)' then score end as 數(shù)學(xué),case when course='英語(yǔ)' then score end as 英語(yǔ) from score;
2、使用group by 和sum,去掉NULL得出課程的成績(jī)
sql語(yǔ)句:
select name ,sum(case when course='語(yǔ)文' then score end) as 語(yǔ)文,sum(case when course='數(shù)學(xué)' then score end )as 數(shù)學(xué),sum(case when course='英語(yǔ)' then score end )as 英語(yǔ)from score group by name;
就是一個(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)容橫過(guò)來(lá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
網(wǎng)站名稱:mysql行轉(zhuǎn)列怎么寫 mysql行轉(zhuǎn)列列轉(zhuǎn)行
本文地址:http://chinadenli.net/article48/hpehep.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、網(wǎng)站設(shè)計(jì)、定制開發(fā)、、網(wǎng)站收錄、網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)