加入收藏 | 设为首页 | 会员中心 | 我要投稿 阜阳站长网 (https://www.0558zz.com/)- 科技、建站、内容创作、云计算、网络安全!
当前位置: 首页 > 数据库 > MsSql > 正文

SQLServer中求两个字符串的交集

发布时间:2020-09-21 06:30:11 所属栏目:MsSql 来源:互联网
导读:代码高亮有点问题,测试时把@ str替换为@str

使用javascript的数组来计算,代码如下:
<div class="codetitle"><a style="CURSOR: pointer" data="14573" class="copybut" id="copybut14573" onclick="doCopy('code14573')"> 代码如下:<div class="codebody" id="code14573">
use tempdb
go
if (object_id ('fn_getArray' ) is not null )
drop function dbo . fn_getArray
go
create function fn_getArray (@ inStr1 varchar (8000 ),@ inStr2 varchar (8000 ))
returns varchar (8000 )
as
begin
declare @ str varchar (8000 )
set @ str = '
var a = [''' + replace (@ inStr1,',''',''' )+ '''];
var b = [''' + replace (@ inStr2,''' )+ '''];
var c=""
for (var i=0;i<a.length;i++)
{
for (var j=0;j<b.length;j++)
{ if(a[i]==b[j]&&c.indexOf(a[i])<0)
c+=a[i]+","
}
}
'
declare @ object int
declare @ r varchar (800 )
exec sp_OACreate 'MSScriptControl.ScriptControl',@ object output
exec sp_OASetProperty @ object,'Language','javascript'
exec sp_OAMethod @ object,'eval',@ r out,@ str
return @ r
end
go
select dbo . fn_getArray ('abc,dced,f23e,gew432','23c,abc,geafd,ged' )
/ 输出
abc,
/

(编辑:阜阳站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读