MySQL LIKE 子句

我们知道在 MySQL 中使用 SELECT 命令来读取数据, 同时我们可以在 SELECT 语句中使用 WHERE 子句来获取指定的记录。

WHERE 子句中可以使用等号 = 来设定获取数据的条件,如 "yssmx_author = 'yssmx.com'"。

但是有时候我们需要获取 yssmx_author 字段含有 "COM" 字符的所有记录,这时我们就需要在 WHERE 子句中使用 LIKE 子句。

LIKE 子句是在 MySQL 中用于在 WHERE 子句中进行模糊匹配的关键字。它通常与通配符一起使用,用于搜索符合某种模式的字符串。

LIKE 子句中使用百分号 % 字符来表示任意字符,类似于UNIX或正则表达式中的星号 *

如果没有使用百分号 % , LIKE 子句与等号 = 的效果是一样的。

语法

以下是 SQL SELECT 语句使用 LIKE 子句从数据表中读取数据的通用语法:

									SELECT column1, column2, ...
FROM table_name
WHERE column_name LIKE pattern;
								

参数说明:

  • column1 , column2 , ... 是你要选择的列的名称,如果使用 * 表示选择所有列。
  • table_name 是你要从中查询数据的表的名称。
  • column_name 是你要应用 LIKE 子句的列的名称。
  • pattern 是用于匹配的模式,可以包含通配符。

更多说明:

  • 你可以在 WHERE 子句中指定任何条件。
  • 你可以在 WHERE 子句中使用LIKE子句。
  • 你可以使用LIKE子句代替等号 =
  • LIKE 通常与 % 一同使用,类似于一个元字符的搜索。
  • 你可以使用 AND 或者 OR 指定一个或多个条件。
  • 你可以在 DELETE 或 UPDATE 命令中使用 WHERE...LIKE 子句来指定条件。

实例

以下是一些 LIKE 子句的使用实例。

1. 百分号通配符 %:

% 通配符表示零个或多个字符。例如, 'a%' 匹配以字母 'a' 开头的任何字符串。

		SELECT * FROM customers WHERE last_name LIKE 'S%';
	

以上 SQL 语句将选择所有姓氏以 'S' 开头的客户。

2. 下划线通配符 _:

_ 通配符表示一个字符。例如, '_r%' 匹配第二个字母为 'r' 的任何字符串。

		SELECT * FROM products WHERE product_name LIKE '_a%';
	

以上 SQL 语句将选择产品名称的第二个字符为 'a' 的所有产品。

3. 组合使用 % 和 _:

		SELECT * FROM users WHERE username LIKE 'a%o_';
	

以上 SQL 语句将选择用户名以 'a' 开头、以 'o' 结尾,并且长度为三个字符的所有用户。

4. 不区分大小写的匹配:

		SELECT * FROM employees WHERE last_name LIKE 'smi%' COLLATE utf8mb4_general_ci;
	

以上 SQL 语句将选择姓氏以 'smi' 开头的所有员工,不区分大小写。

LIKE 子句提供了强大的模糊搜索能力,可以根据不同的模式和需求进行定制。在使用时,请确保理解通配符的含义,并根据实际情况进行匹配。


在命令提示符中使用 LIKE 子句

以下我们将在 SELECT 命令中使用 WHERE...LIKE 子句来从 MySQL 数据表 yssmx_tbl 中读取数据。

实例

以下是我们将 yssmx_tbl 表中获取 yssmx_author 字段中以 COM 为结尾的的所有记录:

SQL LIKE 语句:

mysql > use yssmx ; Database changed mysql > SELECT * from yssmx_tbl WHERE yssmx_author LIKE ' %COM ' ; +-----------+---------------+---------------+-----------------+ | yssmx_id _ yssmx_title _ yssmx_author _ submission_date | +-----------+---------------+---------------+-----------------+ | 3 _学习 Java _ yssmx . COM _ 2015 - 05 - 01 | | 4 _学习 Python _ yssmx . COM _ 2016 - 03 - 06 | +-----------+---------------+---------------+-----------------+ 2 rows in set ( 0.01 sec )

在 PHP 脚本中使用 LIKE 子句

你可以使用 PHP 函数的 mysqli_query() 及相同的 SELECT 带上 WHERE...LIKE 子句的命令来获取数据。

该函数用于执行 SQL 命令,然后通过 PHP 函数 mysqli_fetch_array() 来输出所有查询的数据。

但是如果是 DELETE 或者 UPDATE 中使用 WHERE...LIKE 子句的S QL 语句,则无需使用 mysqli_fetch_array() 函数。

实例

以下是我们使用PHP脚本在 yssmx_tbl 表中读取 yssmx_author 字段中以 COM 为结尾的的所有记录:

MySQL LIKE 子句测试:

<?php $dbhost = ' localhost ' ; // mysql服务器主机地址 $dbuser = ' root ' ; // mysql用户名 $dbpass = ' 123456 ' ; // mysql用户名密码 $conn = mysqli_connect ( $dbhost , $dbuser , $dbpass ) ; if ( ! $conn ) { die ( ' 连接失败: ' . mysqli_error ( $conn ) ) ; } // 设置编码,防止中文乱码 mysqli_query ( $conn , " set names utf8 " ) ; $sql = ' SELECT yssmx_id, yssmx_title, yssmx_author, submission_date FROM yssmx_tbl WHERE yssmx_author LIKE "%COM" ' ; mysqli_select_db ( $conn , ' yssmx ' ) ; $retval = mysqli_query ( $conn , $sql ) ; if ( ! $retval ) { die ( ' 无法读取数据: ' . mysqli_error ( $conn ) ) ; } echo ' <h2>云搜索MX教程 mysqli_fetch_array 测试<h2> ' ; echo ' <table border="1"><tr><td>教程 ID</td><td>标题</td><td>作者</td><td>提交日期</td></tr> ' ; while ( $row = mysqli_fetch_array ( $retval , MYSQLI_ASSOC ) ) { echo " <tr><td> {$row['yssmx_id']} </td> " . " <td> {$row['yssmx_title']} </td> " . " <td> {$row['yssmx_author']} </td> " . " <td> {$row['submission_date']} </td> " . " </tr> " ; } echo ' </table> ' ; mysqli_close ( $conn ) ; ?>

输出结果如下图所示: