SQL 比较中文字符串
/*
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 比较中文字符串的更多相关文章
- sql server使用sql插入中文字符串乱码问题
在插入语句前加N就行了 sb.Append(string.Format("update chapter set [content]=N'{0}' where Id ={1} ;", ...
- SQL Server 插入含有中文字符串出现乱码现象的解决办法
ELECT COLLATIONPROPERTY('Chinese_PRC_Stroke_CI_AI_KS_WS', 'CodePage') --查询SQLServer编码格式的语句 下面 ...
- SQL Server:字符串函数
以下所有例子均Studnet表为例: 1. len():计算字符串长度 len()用来计算字符串的长度,每个中文汉字或英文字母都为一个长度 select sname, len(sname) from ...
- asp.net插入sql server 中文乱码问题解决方案
创建数据库的代码---创建promary表 create table promary ( proID int primary key, proName varchar(50) not null ) 出 ...
- 关于TP3.2框架读取Sql server中文字段数据以及处理乱码的一些小心得
最近要做一个项目,需要使用TP3.2框架,之前什么也不会,就硬着头皮上了,结果真的闹了挺多emmmmmm挺低级的错误,就像SQL Server中文字段的读取,一开始我是照着读取英文字段的格式来写的,在 ...
- php 获取中文长度 截取中文字符串
#获取中文长度mb_strlen($str,$encoding); #截取中文字符串 mb_substr(str,start,length,encoding);
- Ajax回调函数返回的中文字符串乱码问题
通过ajax提交请求,返回的response所带的中文字符串一直显示为乱码,写了如下代码也无效: response.setCharacterEncoding("UTF-8"); r ...
- 中文字符串转换为十六进制Unicode编码字符串
package my.unicode; import java.util.regex.Matcher; import java.util.regex.Pattern; public class Uni ...
- js jQuery中文字符串比较
先说下普通字符串(英文)比较: 一般使用双等来判断(==),如果还需要类型相同那么就用三等(===) 1. 双等(==)是完全向后兼容的,如果两个操作数类型不一致,它会在某些时候自动对操作数进行类型转 ...
随机推荐
- openstack私有云布署实践【15 创建租户网络+实例】
这里以办公网测试环境为例, (一)创建租户demo的网络 使用admin用户 source admin-openrc.sh 创建public公网 neutron net-create 1040 ...
- smarty模板设计
一.什么是smarty? smarty是一个使用PHP写出来的模板PHP模板引擎,它提供了逻辑与外在内容的分离,简单的讲,目的就是要使用PHP程序员同美工分离,使用的程序员改变程序的逻辑内容不会影 ...
- 常用的HTTP状态码如下
成功的状态码: – 服务器成功返回网页 – 未修改 失败的状态码: – 请求的网页不存在 – 服务器暂时不可用 – 服务器内部错误 下面的不是很常用,记住上面那几个就ok了,有bug了再补充 其他的状 ...
- [妙味 DOM] 第二课:DOM、BOM相关方法及属性
知识点总结 获取样式.增加样式.删除样式函数的封装 表格 tHead tBodies tFoot rows 行 cells 列 表单 表单可以通过name来获取元素:表单.name值 onchange ...
- hdu_5900_QSC and Master(区间DP)
题目链接:hdu_5900_QSC and Master 题意: 有n个数,每个数有个key值,有个val,如果相邻的两个数的key的gcd大于1那么就可以得到这两个数的val的和,现在问怎么取使得到 ...
- HashMap解惑
HashMap中有一些我们容易忽视的点 1. 关于key的hash和equals public V put(K key, V value) { if (table == EMPTY_TABLE) { ...
- Linux CPU 核数检查脚本
#!/bin/bash physicalNumber=0 coreNumber=0 logicalNumber=0 HTNumber=0 logicalNumber=$(grep "proc ...
- IMAGE服务器软件配置
NFS: vim /etc/exports /bak/www/www.xxxl.com/public/ 10.20.10.0/24(rw,sync,no_root_squash)/bak/www/ww ...
- 一把刀系统维护工具箱 v1.6 绿色版
软件名称: 一把刀系统维护工具箱 软件语言: 简体中文 授权方式: 免费软件 运行环境: Win8 / Win7 / Vista / WinXP 软件大小: 13.7MB 图片预览: 软件简介: 一把 ...
- mysql高级查询
高级查询: 1.连接查询 select * from Info,Nation #得出的结果称为笛卡尔积select * from Info,Nation where Info.Nation = Nat ...