zoukankan      html  css  js  c++  java
  • 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,
    */
  • 相关阅读:
    CSS
    引入缺陷的原因都有哪些?
    测试基础---软件研发中几个重要的过程是什么,每个过程中的主要内容是什么?
    测试基础---软件生命周期中的各个模型及其优缺点
    测试基础---测试目的是什么
    测试常用术语4
    测试常用术语3
    测试常用术语2
    测试常用术语1
    测试覆盖率
  • 原文地址:https://www.cnblogs.com/cl1024cl/p/6204821.html
Copyright © 2011-2022 走看看