sqlserver中比較一個(gè)字符串中是否含含另一個(gè)字符串中的一個(gè)字符
更新時(shí)間:2010年09月04日 01:24:24 作者:
sql中比較一個(gè)字符串中是否含有另一個(gè)字符串中的一個(gè)字符的實(shí)現(xiàn)代碼,需要的朋友可以參考下。
版本一:按分隔符進(jìn)行比較
算法思路:按分隔符截取搜索字符串循環(huán)與待搜索字符進(jìn)行比較
USE [Fly]
GO
--參數(shù):@inStr 待搜索字串,@fndStr 搜索字串,@doc 分隔符
-- 例:select dbo.fSearch('1,2,3,4,5,6','3,6,5,8,2',',') 返回0-不匹配,返回1-匹配(@instr中有@fndStr內(nèi)容)
--可以用于表搜索,如:
-- Select *,dbo.fSearch(str,'3,6,5,8,2',',') as 是否匹配 from 表名
-- @fndStr和@doc兩個(gè)參數(shù)就需要你自己提供了,@inStr可以是數(shù)據(jù)表里的某個(gè)待搜索字段名
CREATE FUNCTION CGF_FN_Search(@inStr VARCHAR(500),@fndStr VARCHAR(500),@doc VARCHAR(5))
RETURNS INT
AS
BEGIN
DECLARE @i INT,@c VARCHAR(500),@fStr VARCHAR(500)
SET @fStr = @fndStr
WHILE(LEN(@fStr) > 0)
BEGIN
SET @i = Charindex(@doc, @fStr)
IF(@i = 0)
BEGIN
IF(CHARINDEX(@fStr,@inStr) > 0)
RETURN 1
ELSE
RETURN 0
END
ELSE
BEGIN
SET @c = SUBSTRING(@fStr,1,@i-1)
IF(CHARINDEX(@c,@inStr) > 0)
RETURN 1
ELSE
SET @fStr = SUBSTRING(@fStr,@i+LEN(@doc),LEN(@fStr))
END
END
RETURN 0
END
版本二:逐字進(jìn)行比較
算法思路:逐字截取搜索字符串循環(huán)與待搜索字符進(jìn)行比較
USE [Fly]
GO
/****** Object: UserDefinedFunction [dbo].[CGF_FN_SearchChar] Script Date: 09/03/2010 16:42:12 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE FUNCTION [dbo].[CGF_FN_SearchChar](@inStr VARCHAR(500),@fndStr VARCHAR(500))
RETURNS INT
AS
BEGIN
DECLARE @i INT,@f INT,@c VARCHAR(1)
SET @i = 1
SET @f = LEN(@fndStr)
WHILE(@i <= @f)
BEGIN
SET @c = SUBSTRING(@fndStr, @i, @i)
IF(CHARINDEX(@c,@inStr) > 0)
BEGIN
RETURN 1
END
SET @i = @i + 1
END
RETURN 0
END
算法思路:按分隔符截取搜索字符串循環(huán)與待搜索字符進(jìn)行比較
復(fù)制代碼 代碼如下:
USE [Fly]
GO
--參數(shù):@inStr 待搜索字串,@fndStr 搜索字串,@doc 分隔符
-- 例:select dbo.fSearch('1,2,3,4,5,6','3,6,5,8,2',',') 返回0-不匹配,返回1-匹配(@instr中有@fndStr內(nèi)容)
--可以用于表搜索,如:
-- Select *,dbo.fSearch(str,'3,6,5,8,2',',') as 是否匹配 from 表名
-- @fndStr和@doc兩個(gè)參數(shù)就需要你自己提供了,@inStr可以是數(shù)據(jù)表里的某個(gè)待搜索字段名
CREATE FUNCTION CGF_FN_Search(@inStr VARCHAR(500),@fndStr VARCHAR(500),@doc VARCHAR(5))
RETURNS INT
AS
BEGIN
DECLARE @i INT,@c VARCHAR(500),@fStr VARCHAR(500)
SET @fStr = @fndStr
WHILE(LEN(@fStr) > 0)
BEGIN
SET @i = Charindex(@doc, @fStr)
IF(@i = 0)
BEGIN
IF(CHARINDEX(@fStr,@inStr) > 0)
RETURN 1
ELSE
RETURN 0
END
ELSE
BEGIN
SET @c = SUBSTRING(@fStr,1,@i-1)
IF(CHARINDEX(@c,@inStr) > 0)
RETURN 1
ELSE
SET @fStr = SUBSTRING(@fStr,@i+LEN(@doc),LEN(@fStr))
END
END
RETURN 0
END
版本二:逐字進(jìn)行比較
算法思路:逐字截取搜索字符串循環(huán)與待搜索字符進(jìn)行比較
復(fù)制代碼 代碼如下:
USE [Fly]
GO
/****** Object: UserDefinedFunction [dbo].[CGF_FN_SearchChar] Script Date: 09/03/2010 16:42:12 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE FUNCTION [dbo].[CGF_FN_SearchChar](@inStr VARCHAR(500),@fndStr VARCHAR(500))
RETURNS INT
AS
BEGIN
DECLARE @i INT,@f INT,@c VARCHAR(1)
SET @i = 1
SET @f = LEN(@fndStr)
WHILE(@i <= @f)
BEGIN
SET @c = SUBSTRING(@fndStr, @i, @i)
IF(CHARINDEX(@c,@inStr) > 0)
BEGIN
RETURN 1
END
SET @i = @i + 1
END
RETURN 0
END
相關(guān)文章
沒(méi)有SQL Server數(shù)據(jù)庫(kù)時(shí)如何打開(kāi).MDF文件
本文主要介紹了在安裝有Visual Studio 2005或以上的版本的前提下,沒(méi)有安裝SQL Server數(shù)據(jù)庫(kù)也可以打開(kāi).MDF數(shù)據(jù)庫(kù)文件的方法,需要的朋友可以參考下2015-08-08SQL判斷是否"存在",還在用 count 操作?很耗時(shí)的!
這篇文章主要介紹了SQL判斷是否"存在",還在用 count 操作?很耗時(shí)的!本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12MMC提示不能打開(kāi)文件SQLServerEnterpriseManager.MSC的解決方法
MMC不能打開(kāi)文件SQLServerEnterpriseManager.MSC的解決方法,主要是不能很方便的打開(kāi)Microsoft SQL 企業(yè)管理器2010-05-05將ACCESS數(shù)據(jù)庫(kù)遷移到SQLSERVER數(shù)據(jù)庫(kù)兩種方法(圖文詳解)
這篇文章介紹了ACCESS數(shù)據(jù)庫(kù)遷移到SQLSERVER數(shù)據(jù)庫(kù)兩種方法,有需要的朋友可以參考一下2013-10-10SQL創(chuàng)建的幾種存儲(chǔ)過(guò)程
表名和比較字段可以做參數(shù)的存儲(chǔ)過(guò)程2010-05-05