SQL函数中like表示(sql like的用法)

http://www.itjxue.com  2023-01-25 09:24  来源:未知  点击次数: 

SQL Like的用法

1、%:表示零个或多个字符。

可以匹配任意 类型 和任意长度的字符,有些情况下若是中文,请使用两个百分号(%%)表示。

比如:select * from flow_user where username like '%王%';

将会把flow_user这张表里面,列名username中还有“王”的记录全部查询出来。

另外,如果需要找到flow_user这张表里面, 字段 username中既有“唐”,又有“英”的记录,可以使用and条件,

select * from flow_user where username like '%英%' and username like '%唐%';

则可以查询出来所有包含“英”和“唐”的所有内容,“英”和“唐”所在的前后位置无所谓。

若是用select * from flow_user where username like '%英%唐%';

可以查出来包含“英唐”的内容,但是查不出来“唐英”的内容。

2、_:表示任意单个字符。匹配单个任意字符,它常用来限制表达式的字符长度:

select * from flow_user where username like ' 英 ';

只能找到“王英琨”这样username为三个字且中间一个字是“英”的内容。

再比如:select * from flow_user where username like '英__';

只能找到“英雄点”这样username为三个字且第一个字是“英”的内容。

3、[]:表示括号内所列字符中的一个(类似正则表达式)。指定一个字符、字符串或范围,要求所匹配的对象为他们中的任一个。

select * from flow_user where username LIKE'[王李张]飞';

将找出“王飞”“李飞”“张飞”(而不是“张王李飞”)。

如[]内有一系列字符(01234,abcde之类的)则可略写为“0-4”,“a-e”:

select * from flow_user where username like '老[0-9]';

将找出“老1”、“老2”、……、“老9”;

Oracle 10g以上的版本用法为:

select * from flow_user where regexp_like(username, '[张王李]飞');

4、[^]:表示不在括号所列之内的单个字符。其取之和[]相同,但它所要求匹配对象为指定字符以外的任一个字符。

select * from flow_user where username LIKE'[^王李张]飞';

将找出不是“王飞”“李飞”“张飞“的”赵飞“、”吴飞“等。

注:oracle like 不支持正则,你可以使用支持like的正则regexp_like

5、查询内容包含通配符时:

由于通配符的缘故,导致查询特殊字符“%”、“_”、“[”的语句无法正常实现,把特殊字符用“[]”括起来便可以正常查询。

function sqlencode(str)

str=replace(str,"[","[[]") '此句一定要在最前

str=replace(str," ","[ ]")

str=replace(str,"%","[%]")

sqlencode=str

end function

简述 SQL 中 like 运算符的作用 谁可以帮我

LIKE 操作符(模糊查询)

LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式。

SQL LIKE 操作符语法

SELECT column_name(s)

FROM table_name

WHERE column_name LIKE pattern原始的表 (用在例子中的):

Persons 表:

Id LastName FirstName Address City

1 Adams John Oxford Street London

2 Bush George Fifth Avenue New York

3 Carter Thomas Changan Street Beijing

LIKE 操作符实例

例子 1

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

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

SELECT * FROM Persons

WHERE City LIKE 'N%'提示:"%" 可用于定义通配符(模式中缺少的字母)。

结果集:

Id LastName FirstName Address City

2 Bush George Fifth Avenue New York

例子 2

接下来,我们希望从 "Persons" 表中选取居住在以 "g" 结尾的城市里的人:

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

SELECT * FROM Persons

WHERE City LIKE '%g'结果集:

Id LastName FirstName Address City

3 Carter Thomas Changan Street Beijing

例子 3

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

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

SELECT * FROM Persons

WHERE City LIKE '%lon%'结果集:

Id LastName FirstName Address City

1 Adams John Oxford Street London

例子 4

通过使用 NOT 关键字,我们可以从 "Persons" 表中选取居住在不包含 "lon" 的城市里的人:

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

SELECT * FROM Persons

WHERE City NOT LIKE '%lon%'结果集:

Id LastName FirstName Address City

2 Bush George Fifth Avenue New York

3 Carter Thomas

SQL中like的用法

测试表.

CREATE TABLE test_like (

like_value VARCHAR(20)

);

INSERT INTO test_like

SELECT '1234567890' UNION ALL

SELECT '12345' UNION ALL

SELECT 'abca' UNION ALL

SELECT 'adcb' UNION ALL

SELECT 'abcc' UNION ALL

SELECT 'abcd' UNION ALL

SELECT 'abcde' UNION ALL

SELECT 'xyz 10% OFF' UNION ALL

SELECT 'xyz 20% OFF' UNION ALL

SELECT 'xyz_123_abc'

_ 表示仅仅匹配1个字符

SELECT

*

FROM

test_like

WHERE

like_value LIKE '1234_';

like_value

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

12345

(1 行受影响)

% 表示仅仅匹配0个或多个字符

SELECT

*

FROM

test_like

WHERE

like_value LIKE '12345%';

like_value

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

1234567890

12345

(2 行受影响)

使用模式匹配

SELECT

*

FROM

test_like

WHERE

like_value LIKE 'abc[ad]';

like_value

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

abca

abcd

(2 行受影响)

SELECT

*

FROM

test_like

WHERE

like_value LIKE '[1a]%[5e]';

like_value

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

12345

abcde

(2 行受影响)

使用 ESCAPE 定义转义符

SELECT

*

FROM

test_like

WHERE

like_value LIKE '%!%%' ESCAPE '!';

like_value

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

xyz 10% OFF

xyz 20% OFF

(2 行受影响)

SELECT

*

FROM

test_like

WHERE

like_value LIKE '%!_%' ESCAPE '!';

like_value

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

xyz_123_abc

(1 行受影响)

在sql语句中,like所有的用法

在sql结构化查询语言中,like语句有着至关重要的作用。

like语句的语法格式是:select * from 表名 where 字段名 like 对应值(子串),它主要是针对字符型字段的,它的作用是在一个字符型字段列中检索包含对应子串的。

A:% 包含零个或多个字符的任意字符串:

1、like'Mc%' 将搜索以字母 Mc 开头的所有字符串(如 McBadden)。

2、like'%inger' 将搜索以字母 inger 结尾的所有字符串(如 Ringer、Stringer)。

3、like'%en%' 将搜索在任何位置包含字母 en 的所有字符串(如 Bennet、Green、McBadden)。

B:_(下划线) 任何单个字符:

like'_heryl' 将搜索以字母 heryl 结尾的所有六个字母的名称(如 Cheryl、Sheryl)。

C:[ ] 指定范围 ([a-f]) 或集合 ([abcdef]) 中的任何单个字符:?

1,like'[CK]ars[eo]n' 将搜索下列字符串:Carsen、Karsen、Carson 和 Karson(如 Carson)。

2、like'[M-Z]inger' 将搜索以字符串 inger 结尾、以从 M 到 Z 的任何单个字母开头的所有名称(如 Ringer)。

D:[^] 不属于指定范围 ([a-f]) 或集合 ([abcdef]) 的任何单个字符:

like'M[^c]%' 将搜索以字母 M 开头,并且第二个字母不是 c 的所有名称(如MacFeather)。

E:* 它同于DOS命令中的通配符,代表多个字符:

c*c代表cc,cBc,cbc,cabdfec等多个字符。

F:?同于DOS命令中的?通配符,代表单个字符 :

b?b代表brb,bFb等

G:# 大致同上,不同的是代只能代表单个数字。k#k代表k1k,k8k,k0k 。

下面我们来举例说明一下:

例1,查询name字段中包含有“明”字的。

select * from table1 where name like '%明%'

例2,查询name字段中以“李”字开头。

select * from table1 where name like '李*'

例3,查询name字段中含有数字的。

select * from table1 where name like '%[0-9]%'

例4,查询name字段中含有小写字母的。

select * from table1 where name like '%[a-z]%'

例5,查询name字段中不含有数字的。

select * from table1 where name like '%[!0-9]%'

以上例子能列出什么值来显而易见。但在这里,我们着重要说明的是通配符“*”与“%”的区别。

很多朋友会问,为什么我在以上查询时有个别的表示所有字符的时候用"%"而不用“*”?先看看下面的例子能分别出现什么结果:

select * from table1 where name like '*明*'

select * from table1 where name like '%明%'

大家会看到,前一条语句列出来的是所有的记录,而后一条记录列出来的是name字段中含有“明”的记录,所以说,当我们作字符型字段包含一个子串的查询时最好采用“%”而不用“*”,用“*”的时候只在开头或者只在结尾时,而不能两端全由“*”代替任意字符的情况下。

(责任编辑:IT教学网)

更多

推荐新书快递文章