亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 綜合 > 正文

sqlserver 將多行數據查詢合并為一條數據

2024-07-21 02:51:00
字體:
來源:轉載
供稿:網友
sqlserver 將多行數據查詢合并為一條數據 2014-01-24 16:43 by 那時me年少, ... 閱讀, ... 評論, 收藏, 編輯

有這樣一個需求:表T_FUN_TASK為任務表,有字段(TASKID,TASKNAME),表T_FUN_LOGBOOK為日志表,有字段(LOGID,TASKID,LOGDATE),一個任務可持續多天,每天會記錄一條日志。在查詢表T_FUN_TASK時,需將任務表中的 LOGDATE 查詢出來作為一列 LOGDATES顯示。

表 T_FUN_TASK

T_FUN_TASK

T_FUN_LOGBOOK

查詢結果

此結果查詢方法可以用存儲過程輕松實現,這里我要介紹的是sqlserver FOR xml PATH語句的應用,在SQL Server中利用 FOR XML PATH 語句能夠把查詢的數據生成XML數據

且合并為一條數據,看以下示例:

SELECT LOGDATE FROM T_FUN_LOGBOOK WHERE TASKID=231 FOR XML PATH

結果為:

<row> <logdate>2014-01-06T00:00:00</logdate></row><row> <logdate>2014-01-07T00:00:00</logdate></row>

在前面的需求中,我是想要把這2條數據合并到一起且沒有XML標簽,條與條之間用下劃線(_)分隔的,日期的格式也變為了2014/01/07的格式。下面來一步一步來完成需求。

首先,將日期格式轉化為需要的格式:

SELECT CONVERT(VARCHAR(100), LOGDATE, 111) FROM T_FUN_LOGBOOK WHERE TASKID=231 FOR XML PATH

結果變為:

<row>2014/01/06</row><row>2014/01/07</row>

可以發現,轉化字符卷的過程中,把logdate標簽給去掉了?,F在我們要去掉<row>標簽:

SELECT CONVERT(VARCHAR(100), LOGDATE, 111) FROM T_FUN_LOGBOOK WHERE TASKID=231 FOR XML PATH('')

在PATH后面將一個空的字符卷作為參數傳遞,就可以去掉<row>標簽,結果:2014/01/062014/01/07。

現在兩條結果之間很難區分,需要用下劃線將其分隔開來,方法是在CONVERT函數前面加上一個下劃線:

SELECT '_'+CONVERT(VARCHAR(100), LOGDATE, 111) FROM T_FUN_LOGBOOK WHERE TASKID=231 FOR XML PATH('')

結果:_2014/01/06_2014/01/07。

在分析了FOR XML PATH語句之后,就來將這個查詢結果添加到對T_FUN_TASk的查詢結果中去。我的思路是先構建一個子查詢,然后查詢TASK表時LEFT JOIN這個子查詢:

SELECT T1.TASKID,'TASKNAME' AS TASKNAME,T2.LOGDATES FROM T_FUN_TASK T1LEFT JOIN (SELECT TASKID, LOGDATES=(SELECT '_'+CONVERT(VARCHAR(100), LOGDATE, 111) FROM T_FUN_LOGBOOK WHERE TASKID=T1.TASKID FOR XML PATH('')) FROM T_FUN_LOGBOOK T1 GROUP BY TASKID) T2 ON T2.TASKID=T1.TASKIDORDER BY T1.TASKID ASC

運行以上SQL后得到的結果為:

發現LOGDATES值的第一個下劃線應該去掉,于是修改SQL,應用 STUFF函數去掉第一個下劃線:

SELECT T1.TASKID,'TASKNAME' AS TASKNAME,T2.LOGDATES FROM T_FUN_TASK T1LEFT JOIN (SELECT TASKID, LOGDATES=STUFF((SELECT '_'+CONVERT(VARCHAR(100), LOGDATE, 111) FROM T_FUN_LOGBOOK WHERE TASKID=T1.TASKID FOR XML PATH('')),1,1,'') FROM T_FUN_LOGBOOK T1 GROUP BY TASKID) T2ON T2.TASKID=T1.TASKIDORDER BY T1.TASKID ASC

將結果轉化為JSON 返回給前端之后,JS按照下劃線分隔這個字段的值,即可以得到一個任務下面日志的填寫情況。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
性色av一区二区三区在线观看| 国产国语刺激对白av不卡| 久久精品久久精品亚洲人| 久久国产精品电影| 亚洲综合国产精品| 国产精品v日韩精品| 国产精品av在线| 久久久精品久久久| 全球成人中文在线| 亚洲影院色无极综合| 国产精品日日做人人爱| 日本三级久久久| 国产精品美女久久| 97精品视频在线播放| 久久人人爽国产| 亚洲一区999| 午夜精品久久久久久99热| 国产日韩欧美自拍| 欧美孕妇孕交黑巨大网站| 国语自产精品视频在线看抢先版图片| 午夜精品理论片| 欧美国产日韩一区二区三区| 亚洲国产小视频在线观看| 国产女精品视频网站免费| 久久天天躁狠狠躁夜夜av| 日本久久久久久久久| 亚洲午夜未满十八勿入免费观看全集| 日韩欧美成人区| 91免费综合在线| 国产精品久久在线观看| 欧美高清理论片| 8090成年在线看片午夜| 亚洲a一级视频| 91夜夜未满十八勿入爽爽影院| 欧美精品在线免费播放| 欧美裸体男粗大视频在线观看| 日韩成人在线播放| 国产亚洲在线播放| 国产欧美亚洲精品| 日韩大陆欧美高清视频区| 欧美精品第一页在线播放| 91久久在线视频| 中文字幕精品av| 伊人久久精品视频| 亚洲小视频在线| 亚洲成人精品av| 精品国产自在精品国产浪潮| 日韩在线视频中文字幕| 欧美午夜精品久久久久久浪潮| 成人午夜激情免费视频| 国产亚洲免费的视频看| 日韩在线中文字| 久久久久久久久久久人体| 久久国产加勒比精品无码| 欧美一区二区大胆人体摄影专业网站| 国产精品亚洲美女av网站| 中文字幕亚洲专区| 美女啪啪无遮挡免费久久网站| 欧美老女人www| 亚洲欧洲av一区二区| 美日韩精品免费观看视频| 91免费精品国偷自产在线| 亚洲高清不卡av| 97超级碰在线看视频免费在线看| 久久天天躁夜夜躁狠狠躁2022| 日韩电影大全免费观看2023年上| 亚洲国产欧美一区二区丝袜黑人| 欧美大片在线免费观看| 成人精品在线观看| 国产亚洲精品久久久久动| 亚洲欧洲一区二区三区久久| 亚洲精品视频网上网址在线观看| 日韩一区二区三区在线播放| 国产成人激情视频| 精品久久久久久久大神国产| 尤物九九久久国产精品的特点| 久久免费视频观看| 国产一区二区动漫| 欧美色道久久88综合亚洲精品| 日本最新高清不卡中文字幕| 国产精品国语对白| 精品国产一区二区三区久久狼黑人| 91精品在线播放| 亚洲第一精品电影| 国产精品免费电影| 亚洲国产黄色片| 最近中文字幕mv在线一区二区三区四区| 午夜精品免费视频| 精品国产成人av| 欧美国产日产韩国视频| 国产视频精品久久久| 久久久噜噜噜久久中文字免| 国产精品视频精品视频| 欧美午夜电影在线| 亚洲欧美国产精品| 中文字幕亚洲欧美日韩高清| 欧美一级片久久久久久久| 久久精品视频亚洲| 国产视频亚洲精品| 成人黄色免费看| 国产精品久久久久久久9999| 尤物yw午夜国产精品视频| 97热在线精品视频在线观看| 欧美猛交ⅹxxx乱大交视频| 久久人人爽人人爽爽久久| 日韩动漫免费观看电视剧高清| 亚洲奶大毛多的老太婆| 国产精品入口福利| 九九综合九九综合| 不卡av在线播放| 国产精品高清在线观看| 亚洲精品98久久久久久中文字幕| 亚洲直播在线一区| 日韩精品久久久久久福利| 国产乱人伦真实精品视频| 久久人人爽人人爽人人片av高清| 成人美女免费网站视频| 国产精品女主播视频| 日韩精品久久久久久福利| 浅井舞香一区二区| 亚洲视频网站在线观看| 亚洲美女又黄又爽在线观看| 国产香蕉一区二区三区在线视频| 中文日韩在线观看| 68精品久久久久久欧美| 2021久久精品国产99国产精品| 国产小视频国产精品| 91久久久久久久| 97精品视频在线播放| 456亚洲影院| 亚洲已满18点击进入在线看片| 成人a级免费视频| 欧美极品少妇xxxxⅹ喷水| 91视频免费网站| 91免费视频网站| 国产精品久久久久久久久久尿| 热99精品里视频精品| 国产精品第七十二页| 国产精品美女免费视频| 国产日韩欧美中文| 国产精品wwwwww| 欧美高清视频在线观看| 久久久免费高清电视剧观看| 国产一区二区三区在线观看视频| 亚洲国产成人精品女人久久久| 亚洲老头同性xxxxx| 91精品国产高清| 亚洲成av人乱码色午夜| 精品综合久久久久久97| 日韩精品免费在线| 亚洲欧美日韩天堂| 国内精品久久久久影院优| 欧美最近摘花xxxx摘花| 在线成人免费网站| 成人免费看片视频| 久久久久久18| 尤物九九久久国产精品的分类| 日韩视频免费在线| 热门国产精品亚洲第一区在线| 日韩高清免费观看| 自拍视频国产精品| 亚洲国产女人aaa毛片在线| 国内精品视频一区| 久久精品2019中文字幕|