日期:2014-05-18 浏览次数:20822 次
Select Distinct [sid] From 表a Where()
------解决方案--------------------
select distinct t1.sid from a t1 where exists (select 1 from a t2 where t2.sid=t1.sid and t2.cid=1000 and t2.intvalue<=3) and exists (select 1 from a t3 where t3.sid=t1.sid and t3.cid=1001 and t3.stringvalue like '%,5,%')
------解决方案--------------------
IF EXISTS (SELECT 1 FROM SYSOBJECTS WHERE name = 'A') BEGIN DROP TABLE A END GO CREATE TABLE A ( sid INT, cid INT, stringvalue VARCHAR(100), intvalue INT ) INSERT INTO A SELECT 1000, 1000, '',3 UNION SELECT 1000, 1001, '0,2,5,12,', 0 UNION SELECT 1000, 1002, '',3 UNION SELECT 1001, 1000, '',4 UNION SELECT 1001, 1001, '0,2,5,12,', 0 UNION SELECT 1001, 1002, '',3 UNION SELECT 1003, 1000, '',2 UNION SELECT 1003, 1001, '0,1,4,5,7,13,', 0 UNION SELECT 1003, 1002, '',2 SELECT sid FROM A WHERE cid=1000 and intvalue<=3 INTERSECT SELECT Sid FROM A WHERE cid=1001 and stringvalue like '%,5,%' sid 1000 1003
------解决方案--------------------
--> 测试数据:[test] if object_id('[test]') is not null drop table [test] create table [test]([sid] int,[cid] int,[stringvalue] varchar(13),[intvalue] int) insert [test] select 1000,1000,'3',null union all select 1000,1001,'0,2,5,12,',0 union all select 1000,1002,'3',null union all select 1003,1000,'2',null union all select 1003,1001,'0,1,4,5,7,13,',0 union all select 1003,1002,'2',null --你的只需把 and 改成or即可 select * from test where (cid=1000 and intvalue<=3) or (cid=1001 and stringvalue like '%,5,%') /* sid cid stringvalue intvalue 1000 1001 0,2,5,12, 0 1003 1001 0,1,4,5,7,13, 0 */