求职员经过的部门SQL

hc8112_boy 2019-09-06 09:48:04
Create Table #t(iid int identity(1,1),Personcode nvarchar(20),depCode nvarchar(10))
go

Insert into #t(Personcode,depCode) values ('1001','11')
Insert into #t(Personcode,depCode) values ('1001','11')
Insert into #t(Personcode,depCode) values ('1001','21')
Insert into #t(Personcode,depCode) values ('1001','21')
Insert into #t(Personcode,depCode) values ('1001','23')
Insert into #t(Personcode,depCode) values ('1001','23')
Insert into #t(Personcode,depCode) values ('1001','11')
Insert into #t(Personcode,depCode) values ('1001','25')
Insert into #t(Personcode,depCode) values ('1001','15')
Insert into #t(Personcode,depCode) values ('1001','21')
Insert into #t(Personcode,depCode) values ('1001','21')
go
Insert into #t(Personcode,depCode) values ('1002','05')
Insert into #t(Personcode,depCode) values ('1002','10')
Insert into #t(Personcode,depCode) values ('1002','10')
Insert into #t(Personcode,depCode) values ('1002','15')
Insert into #t(Personcode,depCode) values ('1002','15')
Insert into #t(Personcode,depCode) values ('1002','05')
Insert into #t(Personcode,depCode) values ('1002','15')
Insert into #t(Personcode,depCode) values ('1002','20')
Insert into #t(Personcode,depCode) values ('1002','20')

需要得到的结果,personcode经过的depcode,按id排序后去掉重复行

1001 11-21,23-11-25-15-21
1002 05-10-15-05-15-20
...全文
78 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
hc8112_boy 2019-09-16
  • 打赏
  • 举报
回复
天哪,现在CSDN改的怎么给大家分啊,一点结帖直接就跑了。。。
leo_lesley 2019-09-06
  • 打赏
  • 举报
回复

Create Table #t(iid int identity(1,1),Personcode nvarchar(20),depCode nvarchar(10))
go

Insert into #t(Personcode,depCode) values ('1001','11')
Insert into #t(Personcode,depCode) values ('1001','11')
Insert into #t(Personcode,depCode) values ('1001','21')
Insert into #t(Personcode,depCode) values ('1001','21')
Insert into #t(Personcode,depCode) values ('1001','23')
Insert into #t(Personcode,depCode) values ('1001','23')
Insert into #t(Personcode,depCode) values ('1001','11')
Insert into #t(Personcode,depCode) values ('1001','25')
Insert into #t(Personcode,depCode) values ('1001','15')
Insert into #t(Personcode,depCode) values ('1001','21')
Insert into #t(Personcode,depCode) values ('1001','21')
go
Insert into #t(Personcode,depCode) values ('1002','05')
Insert into #t(Personcode,depCode) values ('1002','10')
Insert into #t(Personcode,depCode) values ('1002','10')
Insert into #t(Personcode,depCode) values ('1002','15')
Insert into #t(Personcode,depCode) values ('1002','15')
Insert into #t(Personcode,depCode) values ('1002','05')
Insert into #t(Personcode,depCode) values ('1002','15')
Insert into #t(Personcode,depCode) values ('1002','20')
Insert into #t(Personcode,depCode) values ('1002','20')

--去除连续的重复信息
;WITH cet AS(
SELECT Personcode,depcode,MAX(iid) iid
FROM (
SELECT id = iid - ROW_NUMBER() OVER(PARTITION BY Personcode,depCode ORDER BY iid),*
FROM #t ) t
GROUP BY id,Personcode,depCode

)
--输出结果
SELECT Personcode,depcode = STUFF((SELECT '-' + depcode FROM cet WHERE Personcode = t.Personcode ORDER BY iid FOR XML PATH('') ),1,1,'')
FROM cet t
GROUP BY Personcode


DROP TABLE #t

/*
需要得到的结果,personcode经过的depcode,按id排序后去掉重复行

1001 11-21,23-11-25-15-21
1002 05-10-15-05-15-20


*/
leo_lesley 2019-09-06
  • 打赏
  • 举报
回复

--去除连续的重复信息
;WITH cet AS(
SELECT Personcode,depcode,MAX(iid) iid
FROM (
SELECT id = iid - ROW_NUMBER() OVER(PARTITION BY Personcode,depCode ORDER BY iid),*
FROM #t ) t
GROUP BY id,Personcode,depCode

)
--输出结果
SELECT Personcode,depcode = STUFF((SELECT '-' + depcode FROM cet WHERE Personcode = t.Personcode ORDER BY iid FOR XML PATH('') ),1,1,'')
FROM cet t
GROUP BY Personcode

听雨停了 2019-09-06
  • 打赏
  • 举报
回复

;WITH cte AS (
	SELECT *,iid-ROW_NUMBER() OVER(PARTITION BY personCode,depcode ORDER BY iid) AS col 
	FROM #t
),cte2 AS (
	SELECT *,ROW_NUMBER() OVER(PARTITION BY personCode,depCode,col ORDER BY iid) AS rn 
	FROM cte
),cte3 AS (
	SELECT iid,personCode,depCode 
	FROM cte2
	WHERE rn=1
)
SELECT B.personCode,
       LEFT(DepCodeList, LEN(DepCodeList) -1) AS DepCodeList
FROM   (
           SELECT personCode,
                  (
                      SELECT depCode + '-'
                      FROM   cte3
                      WHERE  personCode = A.personCode
                      ORDER BY
                             iid
                             FOR XML PATH('')
                  ) AS DepCodeList
           FROM   cte3 A
           GROUP BY
                  personCode
       ) B;

personCode           DepCodeList
-------------------- ----------------------
1001                 11-21-23-11-25-15-21
1002                 05-10-15-05-15-20


二月十六 2019-09-06
  • 打赏
  • 举报
回复
;WITH ctea AS (
SELECT
iid,
ROW_NUMBER() OVER (PARTITION BY Personcode, depCode ORDER BY iid) num,
ROW_NUMBER() OVER (PARTITION BY Personcode, depCode ORDER BY iid) - iid rn,
Personcode,
depCode
FROM #t
),cteb AS (
SELECT *,ROW_NUMBER()OVER(PARTITION BY rn,ctea.Personcode,ctea.depCode ORDER BY ctea.iid) rn1 FROM ctea
),ctec AS (
SELECT * FROM cteb WHERE rn1=1
)
select personcode,
depcode = (stuff((select '-' + depcode
from ctec as b
where b.personcode = a.personcode ORDER BY iid
for xml path('') ),
1,
1,
''))
from ctec a
group by a.personcode;



stelf 2019-09-06
  • 打赏
  • 举报
回复
select personcode, depcode = (stuff((select distinct ',' + depcode from #t as b where b.personcode = a.personcode for xml path('')), 1, 1, '')) from #t a group by a.personcode;
SQL语法大全 SQL语法大全 1. ASP与Access数据库连接: 2. ASP与SQL数据库连接: 建立记录集对象: set rs=server.createobject("adodb.recordset") rs.open SQL语句,conn,3,2 3. SQL常用命令使用方法: (1) 数据记录筛选: sql="select * from 数据表 where 字段名=字段值 order by 字段名 [desc]" sql="select * from 数据表 where 字段名 like \'%字段值%\' order by 字段名 [desc]" sql="select top 10 * from 数据表 where 字段名 order by 字段名 [desc]" sql="select * from 数据表 where 字段名 in (\'值1\',\'值2\',\'值3\')" sql="select * from 数据表 where 字段名 between 值1 and 值2" (2) 更新数据记录: sql="update 数据表 set 字段名=字段值 where 条件表达式" sql="update 数据表 set 字段1=值1,字段2=值2 …… 字段n=值n where 条件表达式" (3) 删除数据记录: sql="delete from 数据表 where 条件表达式" sql="delete from 数据表" (将数据表所有记录删除) (4) 添加数据记录: sql="insert into 数据表 (字段1,字段2,字段3 …) values (值1,值2,值3 …)" sql="insert into 目标数据表 select * from 源数据表" (把源数据表的记录添加到目标数据表) (5) 数据记录统计函数: AVG(字段名) 得出一个表格栏平均值 COUNT(*|字段名) 对数据行数的统计或对某一栏有值的数据行数统计 MAX(字段名) 取得一个表格栏最大的值 MIN(字段名) 取得一个表格栏最小的值 SUM(字段名) 把数据栏的值相加 引用以上函数的方法: sql="select sum(字段名) as 别名 from 数据表 where 条件表达式" set rs=conn.excute(sql) 用 rs("别名") 获取统的计值,其它函数运用同上。 (5) 数据表的建立和删除: CREATE TABLE 数据表名称(字段1 类型1(长度),字段2 类型2(长度) …… ) 例:CREATE TABLE tab01(name varchar(50),datetime default now()) DROP TABLE 数据表名称 (永久性删除一个数据表) 4. 记录集对象的方法: rs.movenext 将记录指针从当前的位置向下移一行 rs.moveprevious 将记录指针从当前的位置向上移一行 rs.movefirst 将记录指针移到数据表第一行 rs.movelast 将记录指针移到数据表最后一行 rs.absoluteposition=N 将记录指针移到数据表第N行 rs.absolutepage=N 将记录指针移到第N页的第一行 rs.pagesize=N 设置每页为N条记录 rs.pagecount 根据 pagesize 的设置返回总页数 rs.recordcount 返回记录总数 rs.bof

22,207

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧