网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 手机学院 | 邮件系统 | 网络安全 | 认证考试
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > SQL技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.教你在SQL Server数据库中拆分字.
.SQL Server 2005 SSIS技巧:动态.
.Sql Server 2000数据库日志日益庞.
.SQL Server的链接服务器技术小结.
.2台服务器数据库如何同步? .
.如何删除数据库中的冗余数据(翻.
.使用用于SQL Server的IIS虚拟目录.
.考虑SQL Server安全时所应注意的.
.自动备份SQL Server数据库中用户.
.快速解决日志文件满造成的无法写.
.SAVEPOINT和ROLLBACK TO SAVEPOI.
.用一条SQL实现:一行多个字段数据.
.Sql server中时间查询的一个比较.
.数据库查询结果的动态排序(4).
.适合数据库初学者学习的日期操作.
.SQL Server端口更改后的数据库连.
.SQL Server 2008实现高可用性.
.在SQL Server 2005中实现表的行列.
.讲解SQL Server数据库被挂马的解.
.SQL SERVER 2005 同步复制技术.

解析Microsoft Sql Server中的like语句

发表日期:2008-12-12

LIKE,确定给定的字符串是否与指定的模式匹配。模式可以包含常规字符和通配符字符。模式匹配过程中,常规字符必须与字符串中指定的字符完全匹配。然而,可使用字符串的任意片段匹配通配符。与使用 = 和 != 字符串比较运算符相比,使用通配符可使 LIKE 运算符更加灵活。

如果任何参数都不属于字符串数据类型,Microsoft® SQL Server™ 会将其转换成字符串数据类型(如果可能)。

语法 view plaincopy to clipboardprint?
match_expression [ NOT ] LIKE pattern [ ESCAPE escape_character ] 

match_expression [ NOT ] LIKE pattern [ ESCAPE escape_character ]参数

match_expression

任何字符串数据类型的有效 SQL Server 表达式。

pattern

match_expression 中的搜索模式,可以包含下列有效 SQL Server 通配符。

通配符 描述示例

% 包含零个或更多字符的任意字符串。 WHERE title LIKE '%computer%' 将查找处于书名任意位置的包含单词 computer 的所有书名。

_(下划线) 任何单个字符。 WHERE au_fname LIKE '_ean' 将查找以 ean 结尾的所有 4 个字母的名字(Dean、Sean 等)。

[ ] 指定范围 ([a-f]) 或集合 ([abcdef]) 中的任何单个字符。 WHERE au_lname LIKE '[C-P]arsen' 将查找以arsen 结尾且以介于 C 与 P 之间的任何单个字符开始的作者姓氏,例如,Carsen、Larsen、Karsen 等。

[^] 不属于指定范围 ([a-f]) 或集合 ([abcdef]) 的任何单个字符。 WHERE au_lname LIKE 'de[^l]%' 将查找以 de 开始且其后的字母不为 l 的所有作者的姓氏。

escape_character

字符串数据类型分类中的所有数据类型的任何有效 SQL Server 表达式。escape_character 没有默认值,且必须仅包含一个字符。

结果类型

Boolean

结果值

如果 match_expression 匹配指定模式,LIKE 将返回 TRUE。

注释

当使用 LIKE 进行字符串比较时,模式字符串中的所有字符都有意义,包括起始或尾随空格。如果查询中的比较要返回包含"abc "(abc 后有一个空格)的所有行,则将不会返回包含"abc"(abc 后没有空格)的列所在行。但是可以忽略模式所要匹配的表达式中的尾随空格。如果查询中的比较要返回包含"abc"(abc 后没有空格)的所有行,则将返回以"abc"开始且具有零个或多个尾随空格的所有行。
本贴来自ZDNetChina中文社区 http://bbs.zdnet.com.cn ,本贴地址:http://bbs.zdnet.com.cn/viewthread.php?tid=94371

由于数据存储方式的原因,使用包含 char 和 varchar 数据模式的字符串比较可能无法通过 LIKE 比较。了解每种数据类型的存储方式以及导致 LIKE 比较失败的原因十分重要。下面的示例将局部 char 变量传递给存储过程,然后使用模式匹配查找某个作者的所有著作。在此过程中,用一个性氏作为变量传递。 view plaincopy to clipboardprint?
CREATE PROCEDURE find_books @AU_LNAME char(20)  
 
AS 
 
SELECT @AU_LNAME = RTRIM(@AU_LNAME) + '%' 
 
SELECT t.title_id, t.title  
 
FROM authors a, titleauthor ta, titles t  
 
WHERE a.au_id = ta.au_id AND ta.title_id = t.title_id  
 
AND a.au_lname LIKE @AU_LNAME 

CREATE PROCEDURE find_books @AU_LNAME char(20)

AS

SELECT @AU_LNAME = RTRIM(@AU_LNAME) + '%'

SELECT t.title_id, t.title

FROM authors a, titleauthor ta, titles t

WHERE a.au_id = ta.au_id AND ta.title_id = t.title_id

AND a.au_lname LIKE @AU_LNAME当名字中包含的字符数小于 20 时,char 变量 (@AU_LNAME) 将包含尾随空格,这导致 find_books 过程中没有行返回。由于 au_lname 列为 varchar 类型,所以没有尾随空格。因为尾随空格是有意义的,所以此过程失败。

但下面的示例是成功的,因为尾随空格没有被添加到 varchar 变量中: view plaincopy to clipboardprint?
USE pubs  
 
GO  
 
CREATE PROCEDURE find_books2 @au_lname varchar(20)  
 
AS 
 
SELECT t.title_id, t.title  
 
FROM authors a, titleauthor ta, titles t  
 
WHERE a.au_id = ta.au_id AND ta.title_id = t.title_id  
 
AND a.au_lname LIKE @au_lname + '%' 
 
EXEC find_books2 'ring' 

USE pubs

GO

CREATE PROCEDURE find_books2 @au_lname varchar(20)

AS

SELECT t.title_id, t.title

FROM authors a, titleauthor ta, titles t

WHERE a.au_id = ta.au_id AND ta.title_id = t.title_id

AND a.au_lname LIKE @au_lname + '%'

EXEC find_books2 'ring'下面是结果集:

title_id title

-------- -----------------

MC3021 The Gourmet Microwave

PS2091 Is Anger the Enemy?

PS2091 Is Anger the Enemy?

PS2106 Life Without Fear

(4 row(s) affected)

由于数据存储方式的原因,使用包含 char 和 varchar 数据模式的字符串比较可能无法通过 LIKE 比较。了解每种数据类型的存储方式以及导致 LIKE 比较失败的原因十分重要。下面的示例将局部 char 变量传递给存储过程,然后使用模式匹配查找某个作者的所有著作。在此过程中,用一个性氏作为变量传递。 view plaincopy to clipboardprint?
CREATE PROCEDURE find_books @AU_LNAME char(20)  
 
AS 
 
SELECT @AU_LNAME = RTRIM(@AU_LNAME) + '%' 
 
SELECT t.title_id, t.title  
 
FROM authors a, titleauthor ta, titles t  
 
WHERE a.au_id = ta.au_id AND ta.title_id = t.title_id  
 
AND a.au_lname LIKE @AU_LNAME 

CREATE PROCEDURE find_books @AU_LNAME char(20)

AS

SELECT @AU_LNAME = RTRIM(@AU_LNAME) + '%'

SELECT t.title_id, t.title

FROM authors a, titleauthor ta, titles t

WHERE a.au_id = ta.au_id AND ta.title_id = t.title_id

AND a.au_lname LIKE @AU_LNAME当名字中包含的字符数小于 20 时,char 变量 (@AU_LNAME) 将包含尾随空格,这导致 find_books 过程中没有行返回。由于 au_lname 列为 varchar 类型,所以没有尾随空格。因为尾随空格是有意义的,所以此过程失败。

但下面的示例是成功的,因为尾随空格没有被添加到 varchar 变量中: view plaincopy to clipboardprint?
USE pubs  
 
GO  
 
CREATE PROCEDURE find_books2 @au_lname varchar(20)  
 
AS 
 
SELECT t.title_id, t.title  
 
FROM authors a, titleauthor ta, titles t  
 
WHERE a.au_id = ta.au_id AND ta.title_id = t.title_id  
 
AND a.au_lname LIKE @au_lname + '%' 
 
EXEC find_books2 'ring' 

USE pubs

GO

CREATE PROCEDURE find_books2 @au_lname varchar(20)

AS

SELECT t.title_id, t.title

FROM authors a, titleauthor ta, titles t

WHERE a.au_id = ta.au_id AND ta.title_id = t.title_id

AND a.au_lname LIKE @au_lname + '%'

EXEC find_books2 'ring'下面是结果集:

title_id title

-------- -----------------

MC3021 The Gourmet Microwave

PS2091 Is Anger the Enemy?

PS2091 Is Anger the Enemy?

PS2106 Life Without Fear

(4 row(s) affected)

上一篇:读取随机记录的例子 SQL语句 人气:272
下一篇:每晚12:20触发存诸过程 人气:380
浏览全部like语句的内容 Dreamweaver插件下载 网页广告代码 2009年新年快乐