前往顾页
以后地位: 主页 > 收集编程 > .Net实例教程 >

有关SQL恍惚查询语句

时候:2012-04-04 01:52来源:知行网www.zhixing123.cn 编辑:麦田守望者

履行 数据库查询时,有完整查询和恍惚查询之分。

一般恍惚语句以下:sql-chaxun

SELECT 字段 FROM 表 WHERE 某字段 Like 前提
此中关于前提,SQL供应了四种婚配形式:

1,%:表示肆意0个或多个字符。可婚配肆意范例和长度的字符,有些环境下如果中文,请应用两个百分号(%%)表示。

比如 SELECT * FROM [user] WHERE u_name LIKE ‘%三%’

将会把u_name为“张三”,“张猫三”、“三脚猫”,“唐三藏”等等有“三”的记录全找出来。

别的,如果必要找出u_name中既有“三”又有“猫”的记录,请应用 and前提
SELECT * FROM [user] WHERE u_name LIKE ‘%三%’ AND u_name LIKE ‘%猫%’

 

若应用 SELECT * FROM [user] WHERE u_name LIKE ‘%三%猫%’
固然能搜刮出“三脚猫”,但不克不及搜刮出适合前提的“张猫三”。

2,_: 表示肆意单个字符。婚配单个肆意字符,它常常利用来限定表达式的字符长度语句:

比如 SELECT * FROM [user] WHERE u_name LIKE ‘_三_’
只找出“唐三藏”如许u_name为三个字且中间一个字是“三”的;

再比如 SELECT * FROM [user] WHERE u_name LIKE ‘三__’;
只找出“三脚猫”如许name为三个字且第一个字是“三”的;

3,[ ]:表示括号内所列字符中的一个(近似正则表达式)。指定一个字符、字符串或范围,请求所婚配工具为它们中的任一个。

比如 SELECT * FROM [user] WHERE u_name LIKE ‘[张李王]三’
将找出“张三”、“李三”、“王三”(而不是“张李王三”);

如 [ ] 内有一系列字符(01234、abcde之类的)则可略写为“0-4”、“a-e”
SELECT * FROM [user] WHERE u_name LIKE ‘老[1-9]‘
将找出“老1”、“老2”、……、“老9”;

4,[^ ] :表示不在括号所列以内的单个字符。其取值和 [] 不异,但它请求所婚配工具为指定字符以外的任一个字符。

比如 SELECT * FROM [user] WHERE u_name LIKE ‘[^张李王]三’
将找出不姓“张”、“李”、“王”的“赵三”、“孙三”等;

SELECT * FROM [user] WHERE u_name LIKE ‘老[^1-4]‘;
将解除“老1”到“老4”,寻觅“老5”、“老6”、……

5,查询内容包含通配符时

因为通配符的原因,导致我们查询特别字符“%”、“_”、“[”的语句不克不及一般实现,而把特别字符用“[ ]”括起便可一般查询。据此我们写出以下函数:

function sqlencode(str)
str=replace(str,”[","[[]“) ‘此句必然要在最前

str=replace(str,”_”,”[_]“)
str=replace(str,”%”,”[%]“)
sqlencode=str
end function

在查询前将待查字符串先经该函数措置便可。

------分开线----------------------------
标签(Tag):数据库 SQLServer SQLServer数据库
------分开线----------------------------
保举内容
猜你感兴趣