日期:2014-05-19  浏览次数:20607 次

如何查询出以很不爽的结果?顶者有分。。。。。。。
以前数据库设计不合理,现在要把
ID     Order
1       01
2       0101
3       0102
4       010101
5       01010101


现在要查出类似ID为5的所有上级ID(上级ID就像2是4   和5的上级ID)
print   @values
结果要变成这样

1,2,4

说明:ID5的order   长度是不定的,但最长为18位。
希望高手帮助。。


------解决方案--------------------
declare @values varchar(100)

select @values=isnull(@values, ' ')+ ', '+rtrim(ID) from 表 a,表 b where b.Order like a.Order+ '% ' and b.ID=5

print @values
------解决方案--------------------
select * from table where charindex( ', '+Order, ', '+ '01010101 ')> 0
------解决方案--------------------
CREATE TABLE tbl
(
ID int,
[Order] varchar(10)
)
INSERT INTO tbl
SELECT 1, '01 'UNION ALL
SELECT 2, '0101 'UNION ALL
SELECT 3, '0102 'UNION ALL
SELECT 4, '010101 'UNION ALL
SELECT 5, '01010101 '
SELECT * FROM tbl WHERE charindex( ', '+[Order], ', '+ '01010101 ')> 0 AND LEN([Order]) <LEN( '01010101 ')
--
ID Order
----------- ----------
1 01
2 0101
4 010101

(3 行受影响)
------解决方案--------------------
--参考下2楼的

declare @t table(ID int,[Order] varchar(18))
insert into @t select 1, '01 '
insert into @t select 2, '0101 '
insert into @t select 3, '0102 '
insert into @t select 4, '010101 '
insert into @t select 5, '01010101 '

declare @id varchar(200)
set @id= ' '
select @id=@id+ ', '+ltrim(id) from
(
select id from @t where charindex( ', '+[Order], ', '+ '01010101 ')> 0 and ID!=5
) tb
print stuff(@id,1,1, ' ')

--
1,2,4
------解决方案--------------------
create table table1(ID int,[Order] varchar(18))
insert into table1 select 1, '01 '
insert into table1 select 2, '0101 '
insert into table1 select 3, '0102 '
insert into table1 select 4, '010101 '
insert into table1 select 5, '01010101 '

select * from table1
where charindex([Order],(select [Order] from table1 where id = 5))=1--这里为了避免一些问题最好是=1
------解决方案--------------------

------解决方案--------------------
select * from table1
where charindex([Order],(select [Order] from table1 where id = 5))=1
and [Order] <> (select [Order] from table1 where id = 5)