日期:2014-05-18  浏览次数:20368 次

sql语句查询问题
有两个表,表1中的字段有编码,接收人,   表2中的字段有编码,姓名
其中:1)表1中的接收人是有多个表2中的编码组成的,例如:0001,0002,0003
2)我要得到的是真正的接收人应该是有表2的姓名组成的,例如:小明,小丽,小刚
3)两个表的连接条件是:表1.接收人=表2.编码

下面是表:
表1:   编码       接收人
              1           0001,0003
              2           0001,0002
              3           0001,0002,0003
表2:   编码       姓名  
            0001       小明
            0002       小丽
            0003       小刚

希望大家帮助呀!俺在线等!。。。。。

------解决方案--------------------
编码 接收人
1 0001
1 0003
2 0001
2 0002
3 0001
3 0002
3 0003
表结构改成这样是不是要好点。
------解决方案--------------------
学习...
------解决方案--------------------
select * from 表1 INNER join 表2 ON (right(表1.接收人,4) = 表2.编码)
------解决方案--------------------
SELECT FROM 表1 LEFT JOIN 表2 ON 表1.接收人 = 表2.编号;

------解决方案--------------------
那加个字段好了
编码 编号 接收人
1 1 0001
1 2 0003
2 1 0001
2 2 0002
3 1 0001
3 2 0002
3 3 0003

------解决方案--------------------
简单
select 表1.编码,表2.姓名 from 表1 left join 表2 on 表1.接收人=表2.编码

------解决方案--------------------
用存储过程来实现,要使用游标的

DECLARE cursor_name [ INSENSITIVE ] [ SCROLL ] CURSOR
FOR select_statement
[ FOR { READ ONLY | UPDATE [ OF column_name [ ,...n ] ] } ]

Transact-SQL 扩展语法
DECLARE cursor_name CURSOR
[ LOCAL | GLOBAL ]
[ FORWARD_ONLY | SCROLL ]
[ STATIC | KEYSET | DYNAMIC | FAST_FORWARD ]
[ READ_ONLY | SCROLL_LOCKS | OPTIMISTIC ]
[ TYPE_WARNING ]
FOR select_statement
[ FOR UPDATE [ OF column_name [ ,...n ] ] ]
------解决方案--------------------
create function uf_splitstring
(
@str varchar(8000)--要分拆的字符串
,@spli varchar(10)--字符串分隔符
)
returns @retab table(istr varchar(8000))
as
begin
declare @i int
declare @splen int
select @splen=len(@spli),@i=charindex(@spli,@str)
while @i > 0
begin
insert into @retab
values(left(@str,@i-1))
select @str=substring(@str,@i+@splen,8000)
select @i=charindex(@spli,@str)
end
if @str <> ' ' insert into @retab values(@str)
return
end

select * from uf_splitstring( '1,2,3,4,5,6,7,8 ', ', ')
=================================
这个过程也许对你有用
------解决方案--------------------
select 表1.接收人,表1.编码,((select 姓名 from 表2 where left(表1.接收人,5)=表2.编码)+cast( case when substring(表1.接收人,6,1)= ', '
then ', '+(select 姓名 from 表2 where substring(表1.接收人,7,5)=表2.编码) else ' ' end + case when substring(表1.接收人,12,1)= ', '
then ', '+(select 姓名 from 表2 where substring(表1.接收人,13,5)=表2.编码) else ' ' end as nvarchar(16)) ) as 接收人 from 表2 INNER join 表1 ON (right(表1.接收人,5) = 表2.编码)