如何检查特定国家/地区代码是否存在于包含 MySQL 的单元格中?


对于特定值,使用 FIND_IN_SET()。我们首先创建 −

mysql> create table DemoTable1439
   -> (
   -> CountryId int NOT NULL AUTO_INCREMENT PRIMARY KEY,
   -> CountryCode varchar(20)
   -> );
Query OK, 0 rows affected (0.49 sec)

在表中插入一些记录,使用插入 −

mysql> insert into DemoTable1439(CountryCode) values('1022_US,7894_UK');
Query OK, 1 row affected (0.14 sec)
mysql> insert into DemoTable1439(CountryCode) values('6567_AUS,7894_UK');
Query OK, 1 row affected (0.13 sec)
mysql> insert into DemoTable1439(CountryCode) values('6567_AUS');
Query OK, 1 row affected (0.09 sec)

使用 select 从表中显示所有记录 −

mysql> select * from DemoTable1439;

将输出以下结果 −

+-----------+------------------+
| CountryId | CountryCode      |
+-----------+------------------+
|         1 | 1022_US,7894_UK  |
|         2 | 6567_AUS,7894_UK |
|         3 | 6567_AUS         |
+-----------+------------------+
3 rows in set (0.00 sec)

以下查询用于检查国家/地区代码是否存在于单元格中 −

mysql> select * from DemoTable1439
   -> where find_in_set('6567_AUS',CountryCode) > 0;

将输出以下结果 −

+-----------+------------------+
| CountryId | CountryCode      |
+-----------+------------------+
|         2 | 6567_AUS,7894_UK |
|         3 | 6567_AUS         |
+-----------+------------------+
2 rows in set (0.00 sec)

更新于:12-Nov-2019

218 浏览

开启你的 职业

完成课程,获得认证

开始
广告