/*
declare @str1 varchar(200),@str2 varchar(200)
set @str1=N'江西省南昌市其它区高新区火炬大道809号'
set @str2=N'江西省南昌市其它区高新区火炬大道809号' */
ALTER FUNCTION [dbo].[F_strcompare](@str1 nVARCHAR(200),
@str2 nVARCHAR(200))
RETURNS numeric(3,2)
AS
BEGIN
declare @returnvalue numeric(3,2)
set @returnvalue=0
if len(@str1)=0 or LEN(@str2)=0
begin
return @returnvalue
end /*完全相等与完全包含*/
if @str1=@str2 or charindex(@str1,@str2)>0 or charindex(@str2,@str1)>0
begin
set @returnvalue= 1.0
return @returnvalue
end DECLARE @len INT, --长度
@min int,
@pos INT, --累计符合个数
@currindex int, --上次匹配位置
@index int, --本次匹配位置
@k INT,
@ret numeric(3,1), --相似度
@word nvarchar(200), --进行分解的字符串
@strsource nvarchar(200) --长度较大的字符串 select @pos=0,@index=0,@currindex=0,@k=0 select @len =(
case when LEN(@str1)>LEN(@str2)
then LEN(@str1)
else
LEN(@str2)
end
),
@min=(
case when LEN(@str1)>LEN(@str2)
then LEN(@str2)
else
LEN(@str1)
end
)
,@word=(
case when LEN(@str1)>LEN(@str2)
then @str2
else
@str1
end
)
,@strsource=(
case when LEN(@str1)>LEN(@str2)
then @str1
else
@str2
end
) while @k < @len-1
begin
select @index=charIndex(substring(@word,@k,1),@strsource)
if @index > 0 and @index > @currindex
begin
set @pos = @pos+1
set @currindex=@index
--print @index
end
set @k=@k+1
end --SET @ret = (CAST(@pos * 100.0 / @k AS NUMERIC(3, 0)))
SET @ret= (@pos * 1.0 / @min)
return @ret
End
--select @ret,@k,@pos,@len,@min

  

SQL 比较中文字符串的更多相关文章

  1. sql server使用sql插入中文字符串乱码问题

    在插入语句前加N就行了 sb.Append(string.Format("update chapter set [content]=N'{0}' where Id ={1} ;", ...

  2. SQL Server 插入含有中文字符串出现乱码现象的解决办法

    ELECT  COLLATIONPROPERTY('Chinese_PRC_Stroke_CI_AI_KS_WS', 'CodePage')       --查询SQLServer编码格式的语句 下面 ...

  3. SQL Server:字符串函数

    以下所有例子均Studnet表为例: 1. len():计算字符串长度 len()用来计算字符串的长度,每个中文汉字或英文字母都为一个长度 select sname, len(sname) from ...

  4. asp.net插入sql server 中文乱码问题解决方案

    创建数据库的代码---创建promary表 create table promary ( proID int primary key, proName varchar(50) not null ) 出 ...

  5. 关于TP3.2框架读取Sql server中文字段数据以及处理乱码的一些小心得

    最近要做一个项目,需要使用TP3.2框架,之前什么也不会,就硬着头皮上了,结果真的闹了挺多emmmmmm挺低级的错误,就像SQL Server中文字段的读取,一开始我是照着读取英文字段的格式来写的,在 ...

  6. php 获取中文长度 截取中文字符串

    #获取中文长度mb_strlen($str,$encoding); #截取中文字符串 mb_substr(str,start,length,encoding);

  7. Ajax回调函数返回的中文字符串乱码问题

    通过ajax提交请求,返回的response所带的中文字符串一直显示为乱码,写了如下代码也无效: response.setCharacterEncoding("UTF-8"); r ...

  8. 中文字符串转换为十六进制Unicode编码字符串

    package my.unicode; import java.util.regex.Matcher; import java.util.regex.Pattern; public class Uni ...

  9. js jQuery中文字符串比较

    先说下普通字符串(英文)比较: 一般使用双等来判断(==),如果还需要类型相同那么就用三等(===) 1. 双等(==)是完全向后兼容的,如果两个操作数类型不一致,它会在某些时候自动对操作数进行类型转 ...

随机推荐

  1. JavaScript 属性操作

    <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...

  2. HDU 5845 Best Division

    $dp$,字典树. $dp$递推式很容易知道.dp[i]=max{dp[j]+1} a[j]^..^a[i]<=X,并且$[j,i]$长度不能超过$L$. 但是暴力来复杂度极高,所以需要用字典树 ...

  3. Spring的监听器ContextLoaderListener

    一.作用 ContextLoaderListener监听器的作用就是启动web容器时,自动装配ApplicationContext的配置信息.它实现了ServletContextListener接口, ...

  4. 整体认识flume:Flume介绍、分布式安装、常见问题及解决方案

    问题导读 1.什么是flume? 2.flume包含哪些组件? 3.Flume在读取utf-8格式的文件时会出现解析不了时间戳,该如何解决? Flume是一个分布式.可靠.和高可用的海量日志采集.聚合 ...

  5. magento里获取用户姓名

    Mage::getSingleton('customer/session')->getCustomer()->getFirstname():

  6. PAT 团体程序设计天梯赛-练习集 L1-003. 个位数统计

    给定一个k位整数N = dk-1*10k-1 + ... + d1*101 + d0 (0<=di<=9, i=0,...,k-1, dk-1>0),请编写程序统计每种不同的个位数字 ...

  7. jQuery复习:第二章&第三章

    第二章 一.选择器 1.层次选择器 $(“ancestor descendant”)选取ancestor元素里的所有后代元素 $(“parent > child”)选取parent元素下的chi ...

  8. poj1741_Tree(树的点分治入门题)

    题目链接:poj1741_Tree 题意: 给你一颗n个节点的树,每条边有一个值,问有多少点对(u,v),满足u->v的最短路径小于k. 题解: 典型的树的分治,板子题. #include< ...

  9. AOE 网络

    1.定义 如果在无向环的带权有向图中 - 用有向边表示一个工程中的活动 - 用边上的权值表示活动的持续时间 - 用顶点表示事件 则这样的有向图叫做用边表示活动的网络,简称AOE网络 AOE在工程方面非 ...

  10. Gentoo安装详解(一) -- 安装基本系统

    前期准备 远程登录: 开启ssh服务: /etc/init.d/sshd start 设置密码: passwd 以便使用putty.ssh client远程登录上传stage等(有时在线下载很慢,而局 ...