如何在 MySQL LIKE 子句中使用使用者變數?


我們可以使用 CONCAT() 函式在 LIKE 子句中使用使用者變數。語法如下。

set @anyVariableName='anyValue';
select yourColumnName1,yourColumnName2,yourColumnName3,...N from yourTableName
whereyourColumnName like CONCAT('%', @anyVariableName, '%');

要理解上述語法,我們首先建立一個表。建立表所需的查詢如下。

mysql> create table UserVariableInLike
-> (
-> id int,
-> Name varchar(100),
-> Age int
-> );
Query OK, 0 rows affected (0.83 sec)

使用 insert 命令在表中插入記錄。查詢如下所示。

mysql> insert into UserVariableInLike values(101,'John',23);
Query OK, 1 row affected (0.23 sec)

mysql> insert into UserVariableInLike values(102,'John Smith',24);
Query OK, 1 row affected (0.20 sec)

mysql> insert into UserVariableInLike values(103,'Carol Smith',23);
Query OK, 1 row affected (0.15 sec)

mysql> insert into UserVariableInLike values(104,'Johnson',25);
Query OK, 1 row affected (0.20 sec)

mysql> insert into UserVariableInLike values(105,'Adam Smith',26);
Query OK, 1 row affected (0.21 sec)

使用 select 語句顯示錶中的所有記錄。查詢如下

mysql> select *from UserVariableInLike;

以下是輸出。

+------+-------------+------+
| id   | Name        | Age  |
+------+-------------+------+
| 101  | John        | 23   |
| 102  | John Smith  | 24   |
| 103  | Carol Smith | 23   |
| 104  | Johnson     | 25   |
| 105  | Adam Smith  | 26   |
+------+-------------+------+
5 rows in set (0.00 sec)

以下是使用 LIKE 子句中的使用者變數的查詢。查詢如下−

mysql> set @searchName='John';
Query OK, 0 rows affected (0.00 sec)

mysql> select id,Name,Age from UserVariableInLike where Name like CONCAT('%',
@searchName, '%');

以下是輸出。

+------+------------+------+
| id   | Name       | Age  |
+------+------------+------+
| 101  | John       | 23   |
| 102  | JohnSmith  | 24   |
| 104  | Johnson    | 25   |
+------+------------+------+
3 rows in set (0.05 sec)

更新於: 29-6月-2020

3K+ 瀏覽量

啟動你的 職業生涯

透過完成課程獲得認證

開始
廣告