我是靠谱客的博主 健忘银耳汤,最近开发中收集的这篇文章主要介绍SQLServer中求两个字符串的交集,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

代码高亮有点问题,测试时把@ str替换为@str

使用javascript的数组来计算,代码如下:
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,f23e,geafd,ged' )


/* 输出
    abc,f23e,
*/

最后

以上就是健忘银耳汤为你收集整理的SQLServer中求两个字符串的交集的全部内容,希望文章能够帮你解决SQLServer中求两个字符串的交集所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(46)

评论列表共有 0 条评论

立即
投稿
返回
顶部