MySQL 的 LIKE 运算符和等于 (=) 运算符之间有什么显著区别?


我们已经了解了用于从 MySQL 表中提取数据的 MySQL SELECT 命令。我们还可以使用称为 WHERE 子句的条件子句来选择所需记录。

当我们需要进行精确匹配时,带有“等于”符号 (=) 的 WHERE 子句效果很好。例如,“tutorial_author = 'Sanjay'”。但是,我们可能需要筛选所有 tutorial_author 名称包含“jay”的结果。这可以使用 WHERE 子句结合 MySQL LIKE 运算符来处理。

如果 MySQL LIKE 运算符不使用通配符,则 LIKE 运算符与 WHERE 子句一起使用的等于号完全相同。

示例

mysql> Select * from Student Where Name LIKE 'Harshit';
+------+---------+---------+----------+--------------------+
| Id   | Name    | Address | Subject  | year_of_admission  |
+------+---------+---------+----------+--------------------+
| 15   | Harshit | Delhi   | Commerce |       2009         |
+------+---------+---------+----------+--------------------+
1 row in set (0.00 sec)

mysql> Select * from Student Where Name = 'Harshit';
+------+---------+---------+----------+--------------------+
| Id   | Name    | Address | Subject  | year_of_admission  |
+------+---------+---------+----------+--------------------+
| 15   | Harshit | Delhi   | Commerce |      2009          |
+------+---------+---------+----------+--------------------+
1 row in set (0.00 sec)

除了具有通配符 % 和 _ 的区别之外,LIKE 和 = 运算符之间的一个显著区别在于 LIKE 运算符不忽略尾随空格,而 = 运算符忽略尾随空格。

示例

mysql> Select * from Student Where Name = 'Harshit ';
+------+---------+---------+----------+--------------------+
| Id   | Name    | Address | Subject  | year_of_admission  |
+------+---------+---------+----------+--------------------+
| 15   | Harshit | Delhi   | Commerce |       2009         |
+------+---------+---------+----------+--------------------+
1 row in set (0.00 sec)

mysql> Select * from Student Where Name LIKE 'Harshit ';
Empty set (0.00 sec)

更新于:2020年2月7日

3K+ 次浏览

启动你的职业生涯

完成课程获得认证

开始学习
广告