SQL 查询一个表中的一列数据是否在另一列全部存在

Select * From emp e
    Where not exists(
        Select item From eFN_split('4,7',',') b where not exists 
            (
                Select item From eFN_split(e.lables,',') a
                    Where b.item=a.item 
            )
        )

4,7是我所输入的参数, efn_split函数功能是截取字符串为表格,

create function eFN_split(
	@string nvarchar(255),--待分割字符串
	@separator nvarchar(255)--分割符
)returns @array table(item nvarchar(255))
as
begin
	declare @begin int,@end int,@item nvarchar(255)
	set @begin = 1
	set @end=charindex(@separator,@string,@begin)
while(@end<>0)
	begin
		set @item = substring(@string,@begin,@end-@begin)
		insert into @array(item) values(@item)
		set @begin = @end+1
		set @end=charindex(@separator,@string,@begin)
	end
	set @item = substring(@string,@begin,len(@string)+1-@begin)
	if (
len(@item)>0)
		insert into @array(item) values(substring(@string,@begin,len(@string)+1-@begin))
	return
end

 

需求是:

一个人有多个标签,标签存储在 lables字段中(多个标签以逗号分隔存储在字段中)

现在想输入多个标签,查询出包含输入标签的人

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值