如何在MySQL中搜索完全匹配的字符串?
你可以使用 binary 来在 MySQL 中搜索完全匹配的字符串。其语法如下:
SELECT * FROM yourTableName WHERE BINARY yourColumnName = yourStringValue;
为了理解上述语法,我们创建一个表。创建表的查询语句如下:
mysql> create table ExactSearch
-> (
-> Id int NOT NULL AUTO_INCREMENT,
-> UserId varchar(10),
-> UserName varchar(20),
-> PRIMARY KEY(Id)
-> );
Query OK, 0 rows affected (0.69 sec)
使用 insert 命令将一些记录插入到表中。查询语句如下:
mysql> insert into ExactSearch(UserId,UserName) values('USER12','John');
Query OK, 1 row affected (0.11 sec)
mysql> insert into ExactSearch(UserId,UserName) values('12USER','Carol');
Query OK, 1 row affected (0.20 sec)
mysql> insert into ExactSearch(UserId,UserName) values('USER123','Bob');
Query OK, 1 row affected (0.15 sec)
mysql> insert into ExactSearch(UserId,UserName) values('USER231','Sam');
Query OK, 1 row affected (0.18 sec)
使用 select 语句显示表中的所有记录:
mysql> select *from ExactSearch;
输出如下:
+----+---------+----------+
| Id | UserId | UserName |
+----+---------+----------+
| 1 | USER12 | John |
| 2 | 12USER | Carol |
| 3 | USER123 | Bob |
| 4 | USER231 | Sam |
+----+---------+----------+
4 rows in set (0.00 sec)
下面是在 MySQL 中搜索完全匹配的字符串的查询语句。我们搜索字符串“USER123”:
mysql> select *from ExactSearch where binary UserId = 'USER123';
输出如下:
+----+---------+----------+
| Id | UserId | UserName |
+----+---------+----------+
| 3 | USER123 | Bob |
+----+---------+----------+
1 row in set (0.00 sec)
阅读更多:MySQL 教程
极客教程