列保存多個(gè)id(將多個(gè)用逗號(hào)隔開的id轉(zhuǎn)換成用逗號(hào)隔開的名稱

列保存多個(gè)id(將多個(gè)用逗號(hào)隔開的id轉(zhuǎn)換成用逗號(hào)隔開的名稱

ID:30095776

大小:93.74 KB

頁(yè)數(shù):6頁(yè)

時(shí)間:2018-12-26

列保存多個(gè)id(將多個(gè)用逗號(hào)隔開的id轉(zhuǎn)換成用逗號(hào)隔開的名稱_第1頁(yè)
列保存多個(gè)id(將多個(gè)用逗號(hào)隔開的id轉(zhuǎn)換成用逗號(hào)隔開的名稱_第2頁(yè)
列保存多個(gè)id(將多個(gè)用逗號(hào)隔開的id轉(zhuǎn)換成用逗號(hào)隔開的名稱_第3頁(yè)
列保存多個(gè)id(將多個(gè)用逗號(hào)隔開的id轉(zhuǎn)換成用逗號(hào)隔開的名稱_第4頁(yè)
列保存多個(gè)id(將多個(gè)用逗號(hào)隔開的id轉(zhuǎn)換成用逗號(hào)隔開的名稱_第5頁(yè)
資源描述:

《列保存多個(gè)id(將多個(gè)用逗號(hào)隔開的id轉(zhuǎn)換成用逗號(hào)隔開的名稱》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在應(yīng)用文檔-天天文庫(kù)

1、在做項(xiàng)目時(shí),經(jīng)常會(huì)遇到這樣的表結(jié)構(gòu)在主表的中有一列保存的是用逗號(hào)隔開ID背景:在做項(xiàng)目時(shí),經(jīng)常會(huì)遇到這樣的表結(jié)構(gòu)在主表的中有一列保存的是用逗號(hào)隔開ID。如,當(dāng)一個(gè)員工從屬多個(gè)部門時(shí)、當(dāng)一個(gè)項(xiàng)目從屬多個(gè)城市時(shí)、當(dāng)一個(gè)設(shè)備從屬多個(gè)項(xiàng)目時(shí),很多人都會(huì)在員工表中加入一個(gè)deptIdsVARCHAR(1000)列(本文以員工從屬多個(gè)部門為例),用以保存部門編號(hào)列表(很明顯這不符合第一范式,但很多人這樣設(shè)計(jì)了,在這篇文章中我們暫不討論在這種應(yīng)用場(chǎng)景下,如此設(shè)計(jì)的對(duì)與錯(cuò),有興趣的可以在回復(fù)中聊聊),然后我們?cè)诓樵?/p>

2、列表中需要看到這個(gè)員工從屬哪些部門。初始化數(shù)據(jù):部門表、員工表數(shù)據(jù):復(fù)制代碼代碼如下:IFEXISTS(SELECT*FROMsys.objectsWHEREobject_id=OBJECT_ID(N'[dbo].[Department]'))DROPTABLE[dbo].DepartmentGO--部門表CREATETABLEDepartment(idint,namenvarchar(50))INSERTINTODepartment(id,name)SELECT1,'人事部'UNIONSELECT

3、2,'工程部'UNIONSELECT3,'管理部'SELECT*FROMDepartmentIFEXISTS(SELECT*FROMsys.objectsWHEREobject_id=OBJECT_ID(N'[dbo].[Employee]'))DROPTABLE[dbo].EmployeeGO--員工表CREATETABLEEmployee(idint,namenvarchar(20),deptIdsvarchar(1000))INSERTINTOEmployee(id,name,deptIds)

4、SELECT1,'蔣大華','1,2,3'UNIONSELECT2,'小明','1'UNIONSELECT3,'小華',''SELECT*FROMEmployee希望得到的結(jié)果:解決方法:第一步,是得到如下的數(shù)據(jù)。即將員工表集合與相關(guān)的部門集合做交叉連接,其中使用了fun_SplitIds函數(shù)(作用是將ids分割成id列表),然后員工集合與這個(gè)得到的集合做交叉連接復(fù)制代碼代碼如下:SELECTE.*,ISNULL(D.name,'')ASdeptNameFROMEmployeeASEOUTERAPP

5、LYdbo.fun_SplitIds(E.deptIds)ASDIDLEFTJOINDepartmentASDONDID.ID=D.id;第二步,已經(jīng)得到了如上的數(shù)據(jù),然后要做的就是根據(jù)ID分組,并對(duì)deptName列做聚合操作,但可惜的是SQLSERVER還沒有提供對(duì)字符串做聚合的操作。但想到,我們處理樹形結(jié)構(gòu)數(shù)據(jù)時(shí),用CTE來做關(guān)系數(shù)據(jù),做成有樹形格式的數(shù)據(jù),如此我們也可以將這個(gè)問題轉(zhuǎn)換成做樹形格式的問題,代碼如下:復(fù)制代碼代碼如下:;WITHEmployeTAS(--員工的基本信息(使用OUT

6、ERAPPLY將多個(gè)ID拆分開來,然后與部門表相關(guān)聯(lián))--此時(shí)已將員工表所存的IDS分別與部門相關(guān)聯(lián),下面需要將此集合中的deptName聚合成一個(gè)記錄SELECTE.*,ISNULL(D.name,'')ASdeptNameFROMEmployeeASEOUTERAPPLYdbo.fun_SplitIds(E.deptIds)ASDIDLEFTJOINDepartmentASDONDID.ID=D.id),mikeAS(SELECTid,name,deptIds,deptName,ROW_NUMB

7、ER()OVER(PARTITIONBYidORDERBYid)ASlevel_numFROMEmployeT),mike2AS(SELECTid,name,deptIds,CAST(deptNameASNVARCHAR(100))ASdeptName,level_numFROMmikeWHERElevel_num=1UNIONALLSELECTm.id,m.name,m.deptIds,CAST(m2.deptName+','+m.deptNameASNVARCHAR(100))ASdeptNam

8、e,m.level_numFROMmikeASmINNERJOINmike2ASm2ONm.ID=m2.idANDm.level_num=m2.level_num+1),maxMikeByIDTAS(SELECTid,MAX(level_num)ASlevel_numFROMmike2GROUPBYID)SELECTA.id,A.name,A.deptIds,A.deptNameFROMmike2ASAINNERJOINmaxMikeByIDTASBONA.id=B.

當(dāng)前文檔最多預(yù)覽五頁(yè),下載文檔查看全文

此文檔下載收益歸作者所有

當(dāng)前文檔最多預(yù)覽五頁(yè),下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學(xué)公式或PPT動(dòng)畫的文件,查看預(yù)覽時(shí)可能會(huì)顯示錯(cuò)亂或異常,文件下載后無此問題,請(qǐng)放心下載。
2. 本文檔由用戶上傳,版權(quán)歸屬用戶,天天文庫(kù)負(fù)責(zé)整理代發(fā)布。如果您對(duì)本文檔版權(quán)有爭(zhēng)議請(qǐng)及時(shí)聯(lián)系客服。
3. 下載前請(qǐng)仔細(xì)閱讀文檔內(nèi)容,確認(rèn)文檔內(nèi)容符合您的需求后進(jìn)行下載,若出現(xiàn)內(nèi)容與標(biāo)題不符可向本站投訴處理。
4. 下載文檔時(shí)可能由于網(wǎng)絡(luò)波動(dòng)等原因無法下載或下載錯(cuò)誤,付費(fèi)完成后未能成功下載的用戶請(qǐng)聯(lián)系客服處理。