表格数据查询

newboylzy 2008-02-23 12:58:30
现有两张表:
表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    杨六
请问语句该如何写,谢谢!
...全文
131 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
xgcom 2008-02-25
  • 打赏
  • 举报
回复
我看数据库设计有问题。 TempUserID ?
pt1314917 2008-02-23
  • 打赏
  • 举报
回复
烏龜和靈魂太震撼了
凌晨還不睡的說。。。。。。
-------------------
睡的太迟以至于现在才起来。哈哈
liangCK 2008-02-23
  • 打赏
  • 举报
回复
tba
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
dawugui 2008-02-23
  • 打赏
  • 举报
回复
那我搞错了.不好意思
playwarcraft 2008-02-23
  • 打赏
  • 举报
回复
不是啊
連去都沒去過。。。。
晓风残月0110 2008-02-23
  • 打赏
  • 举报
回复
play war3
重庆的说
中国风 2008-02-23
  • 打赏
  • 举报
回复
select 
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+',%'
heshengfen123 2008-02-23
  • 打赏
  • 举报
回复
select 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
playwarcraft 2008-02-23
  • 打赏
  • 举报
回复
烏龜和靈魂太震撼了
凌晨還不睡的說。。。。。。
pt1314917 2008-02-23
  • 打赏
  • 举报
回复

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
dawugui 2008-02-23
  • 打赏
  • 举报
回复
create table A(UserID varchar(10) , UserName varchar(10))
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')
go

select 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.userid

drop table A,B

/*
id userid username
---------- ---------- ----------
16 10 张三
16 11 李四
16 12 王五
16 13 杨六

(所影响的行数为 4 行)
*/
dawugui 2008-02-23
  • 打赏
  • 举报
回复
select 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

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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