首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > SQL Server >

同字段多个like 查询交加

2012-12-17 
同字段多个like 查询交集create table a(name nvarchar(50),value nvarchar(50))insert into a values(a

同字段多个like 查询交集
create table a
(
name nvarchar(50),
value nvarchar(50)
)

insert into a values('a','a1'),('a','a1'),('a','a2'),('a','a3'),('b','b1'),('b','b1'),('b','a1')

我想like查询同时有1和3的name
最后查出的结果只有一行a
[最优解释]

create table a
(
name nvarchar(50),
value nvarchar(50)
)

insert into a values('a','a1'),('a','a1'),('a','a2'),('a','a3'),('b','b1'),('b','b1'),('b','a1')

select * from a  
where 
exists(select 1 from a s where s.name=a.name and s.value like '%1%')
and exists(select 1 from a s where s.name=a.name and s.value like '%3%')


/*
name                                               value
-------------------------------------------------- --------------------------------------------------
a                                                  a1
a                                                  a1
a                                                  a2
a                                                  a3

(4 行受影响)


*/

[其他解释]
select *
from a
where (name like '%1%' or name like '%3%')
[其他解释]
select distinct name
 from a
 where (name like '%1%' or name like '%3%')
[其他解释]
select name from tb
 where value like '%1%' or value like '%2%'
group by name having count(distinct name)=2

热点排行