SQL LIKE 操作符
LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式。
SQL LIKE 操作符
LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式。
SQL LIKE 语法
SELECT column1, column2, ... FROM table_name WHERE column LIKE pattern;
参数说明:
- column1, column2, ... :要选择的字段名称,可以为多个字段。如果不指定字段名称,则会选择所有字段。
- table_name :要查询的表名称。
- column :要搜索的字段名称。
- pattern :搜索模式。
演示数据库
在本教程中,我们将使用 yssmx 样本数据库。
下面是选自 "Websites" 表的数据:
mysql> SELECT * FROM Websites; +----+---------------+---------------------------+-------+---------+ | id_name _url _alexa_country | +----+---------------+---------------------------+-------+---------+ | 1_Google _https://www.google.cm/ _ 1_USA | | 2_淘宝 _https://www.taobao.com/ _ 13_CN | | 3_云搜索MX教程 _/ _ 5000_USA | | 4_微博 _http://weibo.com/ _ 20_CN | | 5_Facebook _https://www.facebook.com/_ 3_USA | | 7_stackoverflow_http://stackoverflow.com/_ 0_IND | +----+---------------+---------------------------+-------+---------+
SQL LIKE 操作符实例
下面的 SQL 语句选取 name 以字母 "G" 开始的所有客户:
实例
SELECT * FROM Websites
WHERE name LIKE 'G%';
WHERE name LIKE 'G%';
执行输出结果:
提示: "%" 符号用于在模式的前后定义通配符(默认字母)。您将在下一章中学习更多有关通配符的知识。
下面的 SQL 语句选取 name 以字母 "k" 结尾的所有客户:
实例
SELECT * FROM Websites
WHERE name LIKE '%k';
WHERE name LIKE '%k';
执行输出结果:
下面的 SQL 语句选取 name 包含模式 "oo" 的所有客户:
实例
SELECT * FROM Websites
WHERE name LIKE '%oo%';
WHERE name LIKE '%oo%';
执行输出结果:
通过使用 NOT 关键字,您可以选取不匹配模式的记录。
下面的 SQL 语句选取 name 不包含模式 "oo" 的所有客户:
实例
SELECT * FROM Websites
WHERE name NOT LIKE '%oo%';
WHERE name NOT LIKE '%oo%';
执行输出结果: