把tags進行分割,并和id關(guān)聯(lián)起來
創(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è)計,全程項目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)
結(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
你好!
你寫的確實有點復(fù)雜!
你可以分兩步:
1 . 獲取每個人每個學(xué)科的最新考試成績
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 . 進行行專列操作
對上面的數(shù)據(jù)進行行列轉(zhuǎn)化操作,比較常見了!
歡迎追問,望采納
試下這個:
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ù)輸出單個課程的成績
case when course='語文' then score end as 語文case when course='數(shù)學(xué)' then score end as 數(shù)學(xué)case when course='英語' then score end as 英語
sql語句:
select name ,case when course='語文' then score end as 語文,case when course='數(shù)學(xué)' then score end as 數(shù)學(xué),case when course='英語' then score end as 英語 from score;
2、使用group by 和sum,去掉NULL得出課程的成績
sql語句:
select name ,sum(case when course='語文' then score end) as 語文,sum(case when course='數(shù)學(xué)' then score end )as 數(shù)學(xué),sum(case when course='英語' then score end )as 英語from score group by name;
就是一個動態(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
網(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è)計、定制開發(fā)、、網(wǎng)站收錄、網(wǎng)站建設(shè)
聲明:本網(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)