现有两张表:
表A(UserID,UserName)值为
UserID UserName
10 张三
11 李四
12 王五
13 杨六
14 表B(id,UserID,TempUserID)
ID UserID TempUserID
16 10 11,12,13
表B记录用户好友信息,如用户UserID为10,TempUserID值为(11,12,13),表示为用户10有11,12,13三个好友,现想关联表A来显示用户名,结果如下:
ID UserID UserName
16 10 张三
16 11 李四
16 12 王五
16 13 杨六
请问语句该如何写,谢谢!
表A(UserID,UserName)值为
UserID UserName
10 张三
11 李四
12 王五
13 杨六
14 表B(id,UserID,TempUserID)
ID UserID TempUserID
16 10 11,12,13
表B记录用户好友信息,如用户UserID为10,TempUserID值为(11,12,13),表示为用户10有11,12,13三个好友,现想关联表A来显示用户名,结果如下:
ID UserID UserName
16 10 张三
16 11 李四
16 12 王五
16 13 杨六
请问语句该如何写,谢谢!
union all
select b.id , a.userid , a.username from a,b where charindex(','+a.userid+',',','+b.tempuserid+',') > 0
insert into A values('10','张三')
insert into A values('11','李四')
insert into A values('12','王五')
insert into A values('13','杨六')
insert into A values('14','')
create table B(ID varchar(10) , UserID varchar(10) , TempUserID varchar(10))
insert into B values('16', '10', '11,12,13')
goselect b.id , b.userid , a.username from a,b where a.userid = b.userid
union all
select b.id , a.userid , a.username from a,b where charindex(','+a.userid+',',','+b.tempuserid+',') > 0
order by b.id , b.useriddrop table A,B/*
id userid username
---------- ---------- ----------
16 10 张三
16 11 李四
16 12 王五
16 13 杨六(所影响的行数为 4 行)
*/
select b.id , b.userid , username from a,b where a.userid = b.userid
union all
select b.id , a.userid , username from a,b where charindex(','+ltrim(a.userid)+',',','+b.tempuserid+',') > 0
union all
select b.id , a.userid , a.username from a,b where charindex(','+a.userid+',',','+b.tempuserid+',') > 0
t1.ID,t1.userid,t2.UserName
from
b t1
join
a t2 on t1.UserID=t2.UserID
union
select
t1.ID,t1.userid,t2.UserName
from
b t1
join
a t2 on ','+t1.TempUserID+',' like '%,'+t2.UserID+',%'
ID classid name
1 1,2,3 西服
2 2,3 中山装
3 1,3 名裤
tbb
id classname
1 衣服
2 上衣
3 裤子我得的结果是
id classname name
1 衣服,上衣,裤子 西服
2 上衣,裤子 中山装
3 衣服,裤子 名裤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)
as
begin
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,'')
end
go
select id,classid=dbo.f_hb(classid),name from tba
drop function f_hb
/*
id classid name
----------- ------------- ----------
1 衣服,上衣,裤子 西服
2 上衣,裤子 中山装
3 衣服,裤子 名裤
(所影响的行数为 3 行)
*/--第2种方法.update
while(exists (select * from tba,tbb where charindex(tbb.id,tba.classid) >0))
update tba
set classid= replace(classid,tbb.id,tbb.classname)
from tbb
where charindex(tbb.id,tba.classid)>0
select * from tba
/*
ID classid name
----------- -------------------- ----------
1 衣服,上衣,裤子 西服
2 上衣,裤子 中山装
3 衣服,裤子 名裤
(所影响的行数为 3 行)
*/
drop table tba,tbb