一个字段有多个编号,如何关联出姓名
我有两个表,表1:人员表(编号、姓名),表2:任务表(序号、承担任务人员编号,任务名称)
假设数据如下:
人员表有数据:
编号 姓名
1 张三
2 李四
3 王五
任务表有数据:
序号 承担任务人员编号 任务名称
1 2 打水
2 1 扫地
3 1;3 擦玻璃
现在想得到显示数据为:
序号 承担任务人员姓名 任务名称
1 李四 打水
2 张三 扫地
3 张三;王五 擦玻璃
如何写sql语句。
[解决办法]
- SQL code
SELECT 序号,姓名 AS 承担任务人员编号,任务名称FROM 人员表 AS A,任务表 AS BWHERE A.序号 = B.承担任务人员编号
[解决办法]
- SQL code
/*问题描述tbaID classid name1 1,2,3 西服 2 2,3 中山装3 1,3 名裤tbb id classname1 衣服2 上衣3 裤子我得的结果是id classname name1 衣服,上衣,裤子 西服 2 上衣,裤子 中山装3 衣服,裤子 名裤*/-------------------------------------------------------sql server 2000中的写法create table tba(ID int,classid varchar(20),name varchar(10))insert into tba values(1,'1,2,3','西服')insert into tba values(2,'2,3' ,'中山装')insert into tba values(3,'1,3' ,'名裤')create table tbb(ID varchar(10), classname varchar(10))insert into tbb values('1','衣服')insert into tbb values('2','上衣')insert into tbb values('3','裤子')go--第1种方法,创建函数来显示create function f_hb(@id varchar(10))returns varchar(1000)asbegin declare @str varchar(1000) set @str='' select @str=@str+','+[classname] from tbb where charindex(','+cast(id as varchar)+',',','+@id+',')>0 return stuff(@str,1,1,'')endgo select id,classid=dbo.f_hb(classid),name from tbadrop function f_hb/*id classid name ----------- ------------- ---------- 1 衣服,上衣,裤子 西服2 上衣,裤子 中山装3 衣服,裤子 名裤(所影响的行数为 3 行)*/--第2种方法.updatewhile(exists (select * from tba,tbb where charindex(tbb.id,tba.classid) >0))update tbaset classid= replace(classid,tbb.id,tbb.classname)from tbbwhere charindex(tbb.id,tba.classid)>0select * from tba/*ID classid name ----------- -------------------- ---------- 1 衣服,上衣,裤子 西服2 上衣,裤子 中山装3 衣服,裤子 名裤(所影响的行数为 3 行)*/drop table tba,tbb--------------------------------------sql server 2005中先分解tba中的classid,然后再合并classnamecreate table tba(ID int,classid varchar(20),name varchar(10))insert into tba values(1,'1,2,3','西服')insert into tba values(2,'2,3' ,'中山装')insert into tba values(3,'1,3' ,'名裤')create table tbb(ID varchar(10), classname varchar(10))insert into tbb values('1','衣服')insert into tbb values('2','上衣')insert into tbb values('3','裤子')goSELECT id , classname , name FROM( SELECT DISTINCT id , name FROM (select tbc.id , tbc.name , tbb.classname from ( SELECT A.id , A.name , B.classid FROM(SELECT id , name , [classid] = CONVERT(xml,'<root><v>' + REPLACE([classid], ',', '</v><v>') + '</v></root>') FROM tba)A OUTER APPLY(SELECT classid = N.v.value('.', 'varchar(100)') FROM A.[classid].nodes('/root/v') N(v))B ) tbc , tbb where tbc.classid = tbb.id ) T)A OUTER APPLY( SELECT [classname]= STUFF(REPLACE(REPLACE(( SELECT classname FROM (select tbc.id , tbc.name , tbb.classname from ( SELECT A.id , A.name , B.classid FROM(SELECT id , name , [classid] = CONVERT(xml,'<root><v>' + REPLACE([classid], ',', '</v><v>') + '</v></root>') FROM tba)A OUTER APPLY(SELECT classid = N.v.value('.', 'varchar(100)') FROM A.[classid].nodes('/root/v') N(v))B ) tbc , tbb where tbc.classid = tbb.id ) N WHERE id = A.id and name = A.name FOR XML AUTO), '<N classname="', ','), '"/>', ''), 1, 1, ''))Norder by iddrop table tba,tbb/*id classname name----------- -------------- ----------1 衣服,上衣,裤子 西服2 上衣,裤子 中山装3 衣服,裤子 名裤(3 行受影响)*/
[解决办法]
select 序号 ,承担任务人员姓名=a.姓名+b.姓名, 任务名称
from 任务表 join 人员表 a on charindex(a.编号,承担任务人员编号)>0
join 人员表 b on charindex(b.编号,承担任务人员编号)>0
如果承担任务人员人数不是很多的话,可以使用上面的。
如果人数不确定,人数又很多的话,上面的不能满足需求
[解决办法]
SELECT 序号,姓名 AS 承担任务人员编号,任务名称
FROM 人员表 A LEFT JOIN 任务表 B ON A.序号 = B.承担任务人员编号
[解决办法]
- SQL code
SELECT 序号,姓名 AS 承担任务人员编号,任务名称FROM 人员表 A LEFT JOIN 任务表 B ON A.序号 = B.承担任务人员编号
[解决办法]
MSSQL2005及以上版本:
create table t1
(
id int,
name varchar(10)
)
insert into t1
select 1, '张三' union all
select 2, '李四' union all
select 3, '王五'
create table t2
(
id int,
node varchar(10),
mission varchar(10)
)
insert into t2
select 1, '2', '打水' union all
select 2, '1', '扫地' union all
select 3, '1;3', '擦玻璃'
select * from t1
select * from t2
select id,node,stuff((select ';'+name from t1 where CHARINDEX(ltrim(id),t2.node)>0 for xml path('')),1,1,'') as name,
mission from t2
--------------------------------
idnodenamemission
12李四打水
21张三扫地
31;3张三;王五擦玻璃
[解决办法]
- SQL code
create table ta(id int,name varchar(10))insert into taselect 1, '张三' union allselect 2, '李四' union allselect 3, '王五'create table tb(id int,node varchar(10),mission varchar(10))insert into tbselect 1, '2', '打水' union allselect 2, '1', '扫地' union allselect 3, '1;3', '擦玻璃'goselect id,stuff((select ';'+name from ta where CHARINDEX(ltrim(id),tb.node)>0 for xml path('')),1,1,'') as name,mission from tb/*id name mission1 李四 打水2 张三 扫地3 张三;王五 擦玻璃*/
[解决办法]
看错了,这样就可以了
- SQL code
CREATE TABLE ManInfo( ID INT NOT NULL, Name VARCHAR(100) NULL)GOINSERT INTO ManInfoSELECT 1,'张三' UNIONSELECT 2,'李四' UNIONSELECT 3,'王五'CREATE TABLE DutyInfo( ID INT NOT NULL, ManId VARCHAR(100), DutyInfo VARCHAR(100))GOINSERT INTO DutyInfoSELECT 1,'2','打水' UNIONSELECT 2,'1','扫地' UNIONSELECT 3,'1;3','擦玻璃'select ID, stuff(( select ';'+ Name from ManInfo AS A where CHARINDEX(CAST(A.ID AS VARCHAR(10)),B.ManId) > 0 for xml path('')),1,1,'') as Name, DutyInfo from DutyInfo AS B