SQL通配符 sql怎么对文本进行替换

SQL中通配符的使用

SQL2005中使用通配符 % _ [ ] ^

LIKE关键字搜索与指定模式匹配的字符串、日期或时间值。有关详细信息,请参阅数据类型 (Transact-SQL)。LIKE关键字使用常规表达式包含值所要匹配的模式。模式包含要搜索的字符串,字符串中可包含四种通配符的任意组合。

通配符含义

%

包含零个或多个字符的任意字符串。

_

任何单个字符。

[ ]

指定范围(例如 [a-f])或集合(例如[abcdef])内的任何单个字符。

[^]

不在指定范围(例如 [^a - f])或集合(例如[^abcdef])内的任何单个字符。

请将通配符和字符串用单引号引起来,例如:

此查询将查找

Contact

表中区号为 415的所有电话号码:

SELECT Phone

FROM AdventureWorks.Person.Contact

WHERE Phone LIKE '415%'

可以将 NOT LIKE与同样的通配符结合使用。若要查找

Contact

表中区号不是 415的所有电话号码,请使用下列等价查询中的任意一个:

SELECT Phone

FROM AdventureWorks.Person.Contact

WHERE Phone NOT LIKE '415%'

-- Or

SELECT Phone

FROM AdventureWorks.Person.Contact

WHERE NOT Phone LIKE '415%'

IS NOT NULL 子句可与通配符和LIKE 子句结合使用。例如,此查询将从

Contact

表中检索以 415 开头且 IS NOTNULL 的所有电话号码:

USE AdventureWorks;

GO

SELECT Phone

FROM Person.Contact

WHERE Phone LIKE '415%' and Phone ISNOT NULL

重要事项:
包含 LIKE关键字的语句的输出取决于安装过程中选择的排序顺序。有关不同的排序顺序所产生的影响的详细信息,请参阅使用排序规则。

可以在 text 列中使用的唯一 WHERE条件是 LIKE、IS NULL 或 PATINDEX。

不与 LIKE一同使用的通配符将解释为常量而非模式,换言之,这些通配符仅代表其本身的值。以下查询试图查找只由四个字符 415%组成的电话号码。该查询将不会查找以 415 开头的电话号码。有关常量的详细信息,请参阅常量(数据库引擎)。

SELECT Phone

FROM AdventureWorks.Person.Contact

WHERE Phone = '415%'

使用通配符时应着重考虑的另一个问题是对性能的影响。如果表达式以通配符开头,就不能使用索引(就如同给定了姓名 "%mith" 而非"Smith"时,将无法知道应从电话簿的哪一页开始查找)。表达式中间或结尾处的通配符不妨碍索引的使用(就如同在电话簿中一样,如果姓名为"Samuel%",则不论 Samuels 和 Samuelson 是否都在电话簿上,都知道该从何处开始查找。)

搜索通配符字符

可以搜索通配符字符。有两种方法可指定平常用作通配符的字符:

如果使用 LIKE执行字符串比较,模式串中的所有字符(包括每个前导空格和尾随空格)都有意义。如果要求比较返回带有字符串

LIKE 'abc '

(abc后跟一个空格)的所有行,将不会返回列值为 abc(abc后没有空格)的行。但是反过来,情况并非如此。可以忽略模式所要匹配的表达式中的尾随空格。如果要求比较返回带有字符串

LIKE 'abc'

(abc 后没有空格)的所有行,将返回以 abc开头且具有零个或多个尾随空格的所有行。

将通配符作为文字使用

可以将通配符模式匹配字符作为文字字符使用。若要将通配符作为文字字符使用,请将通配符放在方括号中。下表显示了几个使用 LIKE关键字和 [ ] 通配符的示例。

符号含义

LIKE '5[%]'

5%

LIKE '[_]n'

_n

LIKE '[a-cdf]'

a、b、c、d 或 f

LIKE '[-acdf]'

-、a、c、d 或 f

LIKE '[ [ ]'

[

LIKE ']'

]

LIKE 'abc[_]d%'

abc_d 和 abc_de

LIKE 'abc[def]'

abcd、abce 和 abcf

使用 ESCAPE子句的模式匹配

可搜索包含一个或多个特殊通配符的字符串。例如,customers 数据库中的 discounts 表可能存储含百分号 (%)的折扣值。若要搜索作为字符而不是通配符的百分号,必须提供 ESCAPE 关键字和转义符。例如,一个样本数据库包含名为 comment的列,该列含文本 30%。若要搜索在 comment 列中的任何位置包含字符串 30% 的任何行,请指定

WHERE comment LIKE'0!%%' ESCAPE '!'

之类的 WHERE 子句。如果未指定ESCAPE 和转义符,则数据库引擎 将返回包含字符串 30 的所有行。

如 果 LIKE模式中的转义符后面没有字符,则该模式无效并且 LIKE 返回FALSE。如果转义符后面的字符不是通配符,则将放弃转义符并将该转义符后面的字符作为该模式中的常规字符处理。这包括百分号(%)、下划线 (_) 和左括号 ([) 通配符(如果它们包含在双括号 ([ ]) 中)。另外,在双括号字符 ([])内,可以使用转义符并将插入符号 (^)、连字符 () 和右括号 (]) 转义。

转载自:http://losegoat.blog.163.com/blog/static/1822557200852111915785/

SQL 通配符

在搜索数据库中的数据时,SQL 通配符可以替代一个或多个字符。

SQL 通配符必须与 LIKE 运算符一起使用。

在 SQL 中,可使用以下通配符:

通配符描述
%替代一个或多个字符
_仅替代一个字符
[charlist]字符列中的任何单一字符

[^charlist]

SQL通配符 sql怎么对文本进行替换

或者

[!charlist]

不在字符列中的任何单一字符

原始的表 (用在例子中的):

Persons 表:

IdLastNameFirstNameAddressCity
1AdamsJohnOxford StreetLondon
2BushGeorgeFifth AvenueNew York
3CarterThomasChangan StreetBeijing

使用 % 通配符

例子 1

现在,我们希望从上面的 "Persons" 表中选取居住在以 "Ne" 开始的城市里的人:

我们可以使用下面的 SELECT 语句:

SELECT * FROM PersonsWHERE City LIKE 'Ne%'

结果集:

IdLastNameFirstNameAddressCity
2BushGeorgeFifth AvenueNew York

例子 2

接下来,我们希望从 "Persons" 表中选取居住在包含 "lond" 的城市里的人:

我们可以使用下面的 SELECT 语句:

SELECT * FROM PersonsWHERE City LIKE '%lond%'

结果集:

IdLastNameFirstNameAddressCity
1AdamsJohnOxford StreetLondon

使用 _ 通配符

例子 1

现在,我们希望从上面的 "Persons" 表中选取名字的第一个字符之后是 "eorge" 的人:

我们可以使用下面的 SELECT 语句:

SELECT * FROM PersonsWHERE FirstName LIKE '_eorge'

结果集:

IdLastNameFirstNameAddressCity
2BushGeorgeFifth AvenueNew York

例子 2

接下来,我们希望从 "Persons" 表中选取的这条记录的姓氏以 "C" 开头,然后是一个任意字符,然后是"r",然后是任意字符,然后是 "er":

我们可以使用下面的 SELECT 语句:

SELECT * FROM PersonsWHERE LastName LIKE 'C_r_er'

结果集:

IdLastNameFirstNameAddressCity
3CarterThomasChangan StreetBeijing

使用 [charlist] 通配符

例子 1

现在,我们希望从上面的 "Persons" 表中选取居住的城市以 "A" 或 "L" 或 "N" 开头的人:

我们可以使用下面的 SELECT 语句:

SELECT * FROM PersonsWHERE City LIKE '[ALN]%'

结果集:

IdLastNameFirstNameAddressCity
1AdamsJohnOxford StreetLondon
2BushGeorgeFifth AvenueNew York

例子 2

现在,我们希望从上面的 "Persons" 表中选取居住的城市不以 "A" 或 "L" 或 "N"开头的人:

我们可以使用下面的 SELECT 语句:

SELECT * FROM PersonsWHERE City LIKE '[!ALN]%'

结果集:

IdLastNameFirstNameAddressCity
3CarterThomasChangan StreetBeijing

转载自:http://www.w3school.com.cn/sql/sql_wildcards.asp

  

爱华网本文地址 » http://www.aihuau.com/a/25101016/293702.html

更多阅读

Word教程-在Word中如何使用通配符快速查找 word快速查找

Word教程-在Word中如何使用通配符快速查找——简介若要想在Word中使用通配符来调整搜索条件,依次单击“编辑→查找”,或者可以按组合键Ctrl+H弹出“查找和替换”对话窗口进行设置,下面我跟大家说说在Word中如何使用通配

Excel技巧之——巧用含通配符的查找 word查找替换通配符

Excel技巧之——巧用含通配符的查找——简介在使用excel中,不但可以根据用户输入的内容进行精确查找,还可以使用包含通配符的模糊查找,在excel中所支持的通配符包括两个:星号*和问号?,其中*可代替任意数目的字符,可以是单个字符也可以是多

如何直接彻底删除文件 通配符?

如何直接彻底删除文件——简介有时候,我们不想要某个文件或者文件夹,删除之后又需要到回收站清空,那么有没有一种方法直接删除而不经过回收站呢?答案是有的。请跟着我一起做一次你就明白了如何直接彻底删除文件——方法/步骤如何直接彻

1. bash简介及通配符、扩展通配符 bash for i in 1 100

当我们执行一些命令的时候,很多的命令是由bash提供的。如果我们想知道某个命令是否是由bash内置的命令的话,我们可以使用typebash内置命令:bash 通配符 扩展通配符 rhce学习bash linux shell shell编程 shell脚本typefcalias如果想让我

声明:《SQL通配符 sql怎么对文本进行替换》为网友释怀过了分享!如侵犯到您的合法权益请联系我们删除