程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> MSSQL >> sqlserver中比擬一個字符串中能否含含另外一個字符串中的一個字符

sqlserver中比擬一個字符串中能否含含另外一個字符串中的一個字符

編輯:MSSQL

sqlserver中比擬一個字符串中能否含含另外一個字符串中的一個字符。本站提示廣大學習愛好者:(sqlserver中比擬一個字符串中能否含含另外一個字符串中的一個字符)文章只能為提供參考,不一定能成為您想要的結果。以下是sqlserver中比擬一個字符串中能否含含另外一個字符串中的一個字符正文


版本一:按分隔符停止比擬
算法思緒:按分隔符截取搜刮字符串輪回與待搜刮字符停止比擬

USE [Fly]
GO
--參數:@inStr 待搜刮字串,@fndStr 搜刮字串,@doc 分隔符
-- 例:select dbo.fSearch('1,2,3,4,5,6','3,6,5,8,2',',') 前往0-不婚配,前往1-婚配(@instr中有@fndStr內容)
--可以用於表搜刮,如:
-- Select *,dbo.fSearch(str,'3,6,5,8,2',',') as 能否婚配 from 表名
-- @fndStr和@doc兩個參數就須要你本身供給了,@inStr可所以數據內外的某個待搜刮字段名
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

版本二:逐字停止比擬
算法思緒:逐字截取搜刮字符串輪回與待搜刮字符停止比擬

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
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved