SQL语句 SELECT LIKE like用法详解

合集下载

SQL语句SELECTLIKElike用法详解

SQL语句SELECTLIKElike用法详解

SQL语句SELECTLIKElike⽤法详解SQL语句 SELECT LIKE 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等多个字符。

sql语句中like通配符详解

sql语句中like通配符详解
它同于DOS命令中的通配符,代表多个字符。
多个字符
%
%c%代表agdcagd等
这种方法在很多程序中要用到,主要是查询包含子串的。
特殊字符
a
a代表a*a
代替*
单字符
?
b?b代表brb,bFb等
同于DOS命令中的?通配符,代表单个字符
sql语句中like通配符详解 2008-11-02 18:53
在SQL结构化查询语言中,LIKE语句有着至关重要的作用。
LIKE语句的语法格式是:select * from 表名 where 字段名 like 对应值(子串),它主要是针对字符型字段的,它的作用是在一个字符型字段列中检索包含对应子串的。
[!数字]
[!0-9]代表A,b,C,d等
同上
组合类型
字符[范围类型]字符
cc[!a-d]#代表ccF#等
可以和其它几种方式组合使用
假设表table1中有以下记录:
name sex
张小明 男
李明天 男
李a天 女
单数字
#
k#k代表k1k,k8k,k0k
大致同上,不同的是代只能代表单个数字。
字符范围
-
[a-z]代表a到z的26个字母中任意一个
指定一个范围中任意一个
排除
[!字符]
[!a-z]代表9,0,%,*等
它只代表单个字符
数字排除
select * from table1 where name like "*张"
这里用到了通配符“*”,可以说,like语句是和通配符分不开的。下面我们就详细介绍一下通配符。

模糊查询的 sql 语句

模糊查询的 sql 语句

模糊查询的 sql 语句在实际的数据库查询过程中,我们经常会遇到需要模糊查询的情况。

模糊查询是一种根据关键字进行模糊匹配的查询方法,可以找到符合条件的记录,而不需要完全匹配。

SQL 提供了几种常见的模糊查询操作符:LIKE、NOT LIKE、ILIKE、NOT ILIKE。

下面将介绍这些操作符的用法及示例。

1. LIKE 操作符:在 SQL 中,LIKE 用于匹配一个列中的某部分内容。

`SELECT * FROM 表名 WHERE 列名 LIKE 'XXX%'`在上述示例中,LIKE 'XXX%' 表示以 'XXX' 开头的内容。

例如,如果想查询姓李的所有人,可以使用以下 SQL 语句:`SELECT * FROM users WHERE name LIKE '李%'`2. NOT LIKE 操作符:与 LIKE 相反,NOT LIKE 用于排除某一部分内容。

`SELECT * FROM 表名 WHERE 列名 NOT LIKE 'XXX%'`例如,如果想查询姓张的用户以外的所有用户,可以使用以下 SQL 语句:`SELECT * FROM users WHERE name NOT LIKE '张%'`3. ILIKE 操作符:在 SQL 中,ILIKE 不区分大小写地进行模糊查询。

`SELECT * FROM 表名 WHERE 列名 ILIKE 'XXX%'`如果想要查询所有姓Smith或者姓smith的用户,可以使用以下 SQL 语句: `SELECT * FROM users WHERE name ILIKE 'smith%'`4. NOT ILIKE 操作符:与 ILIKE 相反,NOT ILIKE 不区分大小写地排除某一部分内容。

`SELECT * FROM 表名 WHERE 列名 NOT ILIKE 'XXX%'`假设我们想要查询所有用户名字不以字母A开头的用户,可以使用以下 SQL 语句:`SELECT * FROM users WHERE name NOT ILIKE 'a%'`总结:模糊查询是 SQL 中非常常用的功能之一,通过 LIKE、NOT LIKE、ILIKE、NOT ILIKE 操作符,可以很方便地实现模糊查询需求。

sql select like 语句大全及实例

sql select like 语句大全及实例

sql select like 语句大全及实例SQL SELECT LIKE语句用于在数据库中查询与指定模式匹配的数据。

LIKE语句通常与通配符一起使用,通配符可以是百分号(%)表示任意字符,或下划线(_)表示单个字符。

以下是不同情况下使用LIKE语句的一些实例:1.查询以指定字符开头的数据:```SELECT * FROM table_name WHERE column_name LIKE'pattern%';```例如,查询以字母"A"开头的产品名称:```SELECT * FROM products WHERE product_name LIKE 'A%';```2.查询以指定字符结尾的数据:```SELECT * FROM table_name WHERE column_name LIKE '%pattern';```例如,查询以字母"s"结尾的城市名称:```SELECT * FROM cities WHERE city_name LIKE '%s';```3.查询包含指定字符的数据:```SELECT * FROM table_name WHERE column_name LIKE '%pattern%';```例如,查询包含字母"a"的产品名称:```SELECT * FROM products WHERE product_name LIKE '%a%';```4.查询以指定字符开头和结尾的数据:```SELECT * FROM table_name WHERE column_name LIKE'pattern_';```例如,查询以字母"A"开头和以字母"s"结尾的城市名称:```SELECT * FROM cities WHERE city_name LIKE 'A%s';```5.查询指定长度的数据:```SELECT * FROM table_name WHERE column_name LIKE '____';```其中,每个下划线"_"表示一个字符。

SQL语句 SELECT LIKE like用法详解

SQL语句 SELECT LIKE like用法详解
B:_(下划线) 任何单个字符:LIKE'_heryl' 将搜索以字母 heryl 结尾的所有六个字母的名称(如 Cheryl、Sheryl)。
C:[ ] 指定范围 ([a-f]) 或集合 ([abcdef]) 中的任何单个字符: 1,LIKE'[CK]ars[eo]n' 将搜索下列字符串:Carsen、Karsen、Carson 和 Karson(如 Carson)。
例5,查询name字段中不含有数字的。
select * from table1 where name like '%[!0-9]%'
以上例子能列出什么值来显而易见。但在这里,我们着重要说明的是通配符“*”与“%”的区别。
很多朋友会问,为什么我在以上查询时有个别的表示所有字符的时候用"%"而不用“*”?先看看下面的例子能分别出现什么结果:
2、LIKE'[M-Z]inger' 将搜索以字符串 inger 结尾、以从 M 到 Z 的任何单个字母开头的所有名称(如 Ringer)。
D:[^] 不属于指定范围 ([a-f]) 或集合 ([abcdef]) 的任何单个字符:LIKE'M[^c]%' 将搜索以字母 M 开头,并且第二个字母不是 c 的所有名称(如MacFeather)。
A:% 包含零个或多个字符的任意字符串: 1、LIKE'Mc%' 将搜索以字母 Mc 开头的所有字符串(如 McBadden)。
2、LIKE'%inger' 将搜索以字母 inger 结尾的所有字符串(如 Ringer、Stringer)。
3、LIKE'%en%' 将搜索在任何位置包含字母 en 的所有字符串(如 Bennet、Green、McBadden)。

like语句用法sql -回复

like语句用法sql -回复

like语句用法sql -回复Like语句是在SQL中常用的一种查询语句,用于筛选满足指定条件的数据。

在这篇文章中,我们将一步一步回答关于Like语句的常见问题,介绍其用法及注意事项。

第一部分:Like语句概述(200-300字)Like语句是SQL中的一个条件表达式,用于在查询中模糊匹配数据。

它通常与通配符结合使用,以在字符串类型的列中寻找符合特定模式的数据。

Like语句的基本语法如下:SELECT column1, column2, ...FROM table_nameWHERE column_name LIKE pattern;其中,column_name是需要匹配的列名,而pattern是需要匹配的模式。

模式中可以使用通配符来表示不确定的字符。

第二部分:Like语句的通配符(500-800字)Like语句的模式中可以使用两种通配符:百分号()和下划线(_)。

1. 百分号()代表任意字符或任意字符序列的长度。

例如,如果我们使用模式'abc',那么我们将匹配以'abc'开头的任意字符串,后面可以是任意字符或字符序列。

2. 下划线(_)代表单个字符的位置。

如果我们使用模式'a_c',那么我们将匹配以'a'开头和'c'结尾的三个字符字符串,中间位置的字符可以是任意字符。

除了这两种通配符,我们还可以使用转义符(\)来匹配通配符本身,例如,我们可以使用模式'50\'来匹配以字符'50'开头的数据。

需要注意的是,通配符匹配是区分大小写的,它只能匹配等于自身的字符。

第三部分:Like语句的使用示例(600-900字)接下来,我们将通过一些实际的示例来演示Like语句的使用。

1. 假设我们有一个名为'Employees'的表,其中包含一个名为'Name'的列。

我们想要查询以字母'A'开头的姓氏,可以使用如下语句:SELECT NameFROM EmployeesWHERE Name LIKE 'A';2. 如果我们想要查询以字母'A'结尾的名字,可以使用如下语句:SELECT NameFROM EmployeesWHERE Name LIKE 'A';3. 如果我们想要查询名字中包含字母'E'的员工,可以使用如下语句:SELECT NameFROM EmployeesWHERE Name LIKE 'E';4. 如果我们想要查询名字中包含两个连续的字母'O'的员工,可以使用如下语句:SELECT NameFROM EmployeesWHERE Name LIKE 'OO';通过以上示例,我们可以看到Like语句在模糊匹配数据时非常灵活和强大。

oracle sql select like字段

oracle sql select like字段

一、概述在Oracle数据库中,SELECT语句是最基本的查询语句之一,可以用来从数据库表中检索数据。

在SQL SELECT语句中,有一个关键字“LIKE”,它可以用来过滤出符合特定模式的数据。

本文将深入探讨在Oracle SQL中如何使用SELECT语句和LIKE关键字来实现数据的模糊查询。

二、LIKE关键字的用途1. LIKE关键字可以用来进行模糊匹配,比如查找以特定字符开头或结尾的数据。

2. LIKE关键字可以配合通配符来实现更精确的模糊匹配,通配符包括百分号()和下划线(_)。

三、基本语法在Oracle SQL中,使用SELECT语句和LIKE关键字进行模糊查询的基本语法如下所示:```sqlSELECT 列名FROM 表名WHERE 列名 LIKE '模式';```其中,列名代表要查询的列名,表名代表要查询的表名,模式代表用来匹配的模糊模式。

四、使用示例假设我们有一个名为“employees”的表,表中包含了员工的尊称信息。

现在,我们想要查询所有姓氏以“张”开头的员工信息。

可以使用以下SQL语句进行查询:```sqlSELECT *FROM employeesWHERE last_name LIKE '张';```这样就可以查找出所有姓氏以“张”开头的员工信息。

五、通配符的使用除了直接指定具体的字符外,还可以使用通配符来实现更灵活的模糊匹配。

通配符有两种:百分号()和下划线(_)。

1. 百分号()代表零个或多个字符的匹配,可以用来匹配任意字符。

2. 下划线(_)代表一个字符的匹配,可以用来匹配单个字符。

示例:```sql-- 查找所有姓氏以“张”开头,且名字长度为3个字符的员工信息SELECT *FROM employeesWHERE last_name LIKE '张__';```这样就可以查找出所有姓氏以“张”开头,且名字长度为3个字符的员工信息。

sql的like语法

sql的like语法

sql的like语法SQL的LIKE语法用于在数据库中进行模糊查询。

它可以用来匹配一个表达式与字段中的值是否相似或符合特定的模式。

下面是LIKE语法的基本用法:```sqlSELECT 列名 FROM 表名 WHERE 列名 LIKE '模式';```模式可以是一个包含特殊字符的字符串,这些特殊字符为通配符,用于匹配不确定的值。

常见的通配符有两个:1. 百分号(%):匹配零个或多个任意字符。

2. 下划线(_):匹配单个任意字符。

下面是一些LIKE语法的例子:1. 匹配以指定字符开头的值:```sqlSELECT 列名 FROM 表名 WHERE 列名 LIKE '指定字符%';```示例:SELECT name FROM employees WHERE name LIKE 'J%';2. 匹配以指定字符结尾的值:```sqlSELECT 列名 FROM 表名 WHERE 列名 LIKE '%指定字符';```示例:SELECT name FROM employees WHERE name LIKE '%son';3. 匹配包含指定字符的值:```sqlSELECT 列名 FROM 表名 WHERE 列名 LIKE '%指定字符%';```示例:SELECT name FROM employees WHERE name LIKE '%ara%';4. 匹配确定长度的值:```sqlSELECT 列名 FROM 表名 WHERE 列名 LIKE '___';```示例:SELECT name FROM employees WHERE name LIKE 'Ann';以上是LIKE语法的基本用法和常见示例。

你可以根据具体需求,结合通配符和条件表达式来编写更复杂的模糊查询语句。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

SQL语句 SELECT LIKE like用法详解
2009-12-16 13:44
LIKE语句的语法格式是:select * from 表名 where 字段名 like 对应值(子串),它主要是针对字符型字段的,它的作用是在一个字符型字段列中检索包含对应子串的。

假设有一个数据库中有个表table1,在table1中有两个字段,分别是name 和sex二者全是字符型数据。

现在我们要在姓名字段中查询以“张”字开头的记录,语句如下:
select * from table1 where name like "张*"
如果要查询以“张”结尾的记录,则语句如下:
select * from table1 where name like "*张"
这里用到了通配符“*”,可以说,like语句是和通配符分不开的。

下面我们就详细介绍一下通配符。

多个字符
*
c*c代表cc,cBc,cbc,cabdfec等
它同于DOS命令中的通配符,代表多个字符。

多个字符
%
%c%代表agdcagd等
这种方法在很多程序中要用到,主要是查询包含子串的。

特殊字符
a
a代表a*a
代替*
单字符
?
b?b代表brb,bFb等
同于DOS命令中的?通配符,代表单个字符
单数字
#
k#k代表k1k,k8k,k0k
大致同上,不同的是代只能代表单个数字。

字符范围
-
[a-z]代表a到z的26个字母中任意一个
指定一个范围中任意一个
续上
排除
[!字符]
[!a-z]代表9,0,%,*等
它只代表单个字符
数字排除
[!数字]
[!0-9]代表A,b,C,d等
同上
组合类型
字符[范围类型]字符
cc[!a-d]#代表ccF#等
可以和其它几种方式组合使用
例:假设表table1中有以下记录:
name sex
张小明男
李明天男
李a天女
王5五男
王清五男
下面我们来举例说明一下:
查询name字段中包含有“明”字的。

select * from table1 where name like '%明%'
查询name字段中以“李”字开头。

select * from table1 where name like '李*'
查询name字段中含有数字的。

select * from table1 where name like '%[0-9]%'
查询name字段中含有小写字母的。

select * from table1 where name like '%[a-z]%'
查询name字段中不含有数字的。

select * from table1 where name like '%[!0-9]%'
我们着重要说明的是通配符“*”与“%”的区别。

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

大家在写sql 语句的时候,如果是 select .. where 类型的语句,有注意到条件的前后顺序吗?我今天做个小实验。

比如查询地址里包含“海口市”及“振兴路” 两个关键字的数据,一般时候可能会用
select * from dm_addr where addr like '%海口市%' and addr like '%振兴路%' 的形式,但其实这种查询效率不高,原因在于条件的前后顺序。

以下是测试结果
mysql> select count(1) from dm_addr where addr like '%振兴路%' and addr like '%海口市%';
+----------+
| count(1) |
+----------+
| 96 |
+----------+
1 row in set (0.8
2 sec)
mysql> select count(1) from dm_addr where addr like '%海口市%' and addr like '%振兴路%';
+----------+
| count(1) |
+----------+
| 96 |
+----------+
1 row in set (0.91 sec)
我做了很多次查询
where addr like '%海口市%' and addr like '%振兴路%' 总是比 where addr like '%振兴路%' and addr like '%海口市%'
慢,原因是查询是先处理第一条件,然后在处理第二个条件,先查询出所有包含“海口市”的记录,再在这些记录中查询包含"振兴路" 的记录。

对于地址情况,包含“海口市”的记录可能大于"振兴路" 的记录,我做测试的表有2万条数据,已经有大概0.1s的差别。

如果碰到大数据,这个差别会更大。

按以上的分析结果,我们写SQL语句的时候,对于select ...where ... 类型的语句,应该把查询结果范围小的条件放在前面,查询范围大的条件放在后面,这样会提高效率。

对于OR的情况:
测试如下:
mysql> select count(1) from dm_addr where addr like '%海口市%' or addr like '%振兴路%';
+----------+
| count(1) |
+----------+
| 39168 |
+----------+
1 row in set (0.84 sec)
mysql> select count(1) from dm_addr where addr like '%振兴路%' or addr like '%海口市%';
+----------+
| count(1) |
+----------+
| 39168 |
+----------+
1 row in set (0.95 sec)
OR语句的处理过程是这样,对于每一条地址,逐个分析条件,如果符合第一个条件,就不做第二条件的判断,那么我们应该把容易做判断的条件放在前面,比如查询地址里包含“海口市”或“振兴路” 个关键字的数据,按地址一般排法,XX市应该在XX路前。

所以如果用第一种方式,那就效率高,判断有海口市就可以确认这行地址有效了。

所以在写OR类型的条件时,应该把容易判断的条件写在前面。

大地址写在前,小的写在后边
再做一个NOT ... OR .. NOT ... 测试,查询不包含海口市或者不包含振兴路的数据
mysql> select count(1) from dm_addr where addr not like '%海口市%' or addr not like '%振兴路%';
+----------+
| count(1) |
+----------+
| 38752 |
+----------+
1 row in set (0.9
2 sec)
mysql> select count(1) from dm_addr where addr not like '%振兴路%' or addr not like '%海口市%';
+----------+
| count(1) |
+----------+
| 38752 |
+----------+
1 row in set (0.86 sec)
因为每条数据都有海口市,所以对于第一个查询,判断第一个条件都失败了,都需要判断第二个。

对于第二个查询,只要判断第一个条件为真就可以确定这个记录,不需要判断第一个条件,所以第二个查询效率高过第一个。

结论:对于select ... where ... 类型的语句。

对于OR条件,需要把命中率高的条件放在前面。

对于AND条件,需要把条件限制范围小的条件放在前面。

希望这些实验能提高phper 的程序效率。

以上测试是对于mysql 5.0 win 做的。

好象记得ORACLE刚好相反,是先判断最后的条件。

相关文档
最新文档