手机
当前位置:查字典教程网 >编程开发 >mssql数据库 >sql中生成查询的模糊匹配字符串
sql中生成查询的模糊匹配字符串
摘要:ifexists(select*fromdbo.sysobjectswhereid=object_id(N'[dbo].[f_Sql]')a...

ifexists(select*fromdbo.sysobjectswhereid=object_id(N'[dbo].[f_Sql]')andxtypein(N'FN',N'IF',N'TF'))

dropfunction[dbo].[f_Sql]

GO

ifexists(select*fromdbo.sysobjectswhereid=object_id(N'[序数表]')andOBJECTPROPERTY(id,N'IsUserTable')=1)

droptable[序数表]

GO

--为了效率,所以要一个辅助表配合

selecttop1000id=identity(int,1,1)into序数表

fromsyscolumnsa,syscolumnsb

altertable序数表addconstraintpk_id_序数表primarykey(id)

go

/*--根据指定字符串生成查询的模糊匹配字符串

条件连接的关键字为and,or

可以任意指定括号

生成的条件表达式为like模糊匹配

--邹建2004.08(引用请保留此信息)--*/

/*--调用示例

--调用示例

selectA=dbo.f_Sql('(WeborHTMLorInternet)and(ProgrammerorDeveloper)','content')

selectB=dbo.f_Sql('WeborHTMLorInternet','content')

selectC=dbo.f_Sql('(WebandHTML)','content')

selectD=dbo.f_Sql('Web','content')

--*/

--示例函数

createfunctionf_Sql(

@strNvarchar(1000),--要检索的字符串

@fdnamesysname--在那个字段中检索

)returnsNvarchar(4000)

as

begin

declare@rNvarchar(4000)

set@r=''

select@r=@r+case

whensubstring(@str,id,charindex('',@str+'',id)-id)in('or','and')

then''+substring(@str,id,charindex('',@str+'',id)-id)+''

whensubstring(@str,id,1)='('

then'(['+@fdname+']like''%'

+substring(@str,id+1,charindex('',@str+'',id)-id-1)

+'%'''

whensubstring(@str,charindex('',@str+'',id)-1,1)=')'

then'['+@fdname+']like''%'

+substring(@str,id,charindex('',@str+'',id)-id-1)

+'%'')'

else'['+@fdname+']like''%'

+substring(@str,id,charindex('',@str+'',id)-id)

+'%'''

end

from序数表

whereid<=len(@str)

andcharindex('',''+@str,id)-id=0

return(@r)

end

go

【sql中生成查询的模糊匹配字符串】相关文章:

sql 多表连接查询

sql中varchar和nvarchar的区别与使用方法

SQL 截取字符串应用代码

sql条件查询+排序

SQLServer中的通配符和转义字符

sql2008评估期已过的解决办法及序列号

sql 修改表的所有者

Sql语句与存储过程查询数据的性能测试实现代码

sql中返回参数的值

sqlserver子查询报错

精品推荐
分类导航