打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
求两个字符串中相同的汉字及字母的个数

求两个字符串中相同的汉字及字母的个数

分类: SQL函数分享系列

--创建函数

create function [dbo].[funcomparestring]

(

       @stra nvarchar(200),

       @strb nvarchar(200)

)

returns int as

begin

    declare @strbase nvarchar(200)

    declare @rank int

    select @rank=0

       if len(@stra)>len(@strb)

          select @rank=count(*)

          from funsplitchar(@strb)

          where item in(select item from funsplitchar(@stra))

       else

          select @rank=count(*)

          from funsplitchar(@stra)

          where item in(select item from funsplitchar(@strb))

    return @rank

end

go

--创建第二种函数

create function [dbo].[funcomparestring_new]

(

       @stra nvarchar(200),

       @strb nvarchar(200)

)

returns int as

begin

       declare @strbase nvarchar(200)

       declare @rank int

       select @rank=0

       if len(@stra)>len(@strb)

       select @rank=count(*)

           from funsplitchar(@strb)

           where item in(select distinct  item from funsplitchar(@stra))

   else

       select @rank=count(*)

       from

       (

         select distinct * from funsplitchar(@stra)

           where item in(select distinct item from funsplitchar(@strb))

       ) bb

       return @rank

end

 

--以上两个函数有什么不同呢?下面我用个例子来给大家说明一下:

 

--测试示例

select [dbo].[funCompareString]('中国Chinese之家','中国人是Chinese')

 

--结果为:9

 

select [dbo].[funCompareString_new]('中国Chinese之家','中国人是Chinese')

 

--结果为:8

 

--在这两个字符串中,'ese''ese'的重复在第一个函数算个字符重复,

--而在第二个函数中算个字符重复。

--也就是说在第二个函数中,多次相同的重复不累积计算例如ese中的e

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
将一个指针所指向字符串中的大写字母复制到另一个指针所指向的字符串中
string的大小写转换
java类的实例化探究
SQL分割字符串函数
js 2个数组 找出不相同元素
Sql字符串分组Split函数的两种实现方法
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服