MySQL 查询以在同一字段中搜索逗号分隔值之间内容?


请使用 FIND_IN_SET。我们首先创建一个表 -

mysql> create table DemoTable
-> (
-> ListOfValues text
-> );
Query OK, 0 rows affected (0.56 sec)

使用 insert 命令在表中插入一些记录 -

mysql> insert into DemoTable values('10|20|30|40|50|60|100');
Query OK, 1 row affected (0.18 sec)

使用 select 语句显示表中的所有记录 -

mysql> select *from DemoTable;

输出

这将产生以下输出 -

+-----------------------+
| ListOfValues          |
+-----------------------+
| 10|20|30|40|50|60|100 |
+-----------------------+
1 row in set (0.00 sec)

以下是查询在一个字段中搜索逗号分隔值之间的内容 -

mysql> select FIND_IN_SET(100, replace(ListOfValues,'|',',')) from DemoTable;

输出

这将产生以下输出 -

+-------------------------------------------------+
| FIND_IN_SET(100, replace(ListOfValues,'|',',')) |
+-------------------------------------------------+
| 7                                               |
+-------------------------------------------------+
1 row in set (0.04 sec)

更新时间: 30-6 月-2020

416 浏览量

开启您的 职业生涯

通过完成课程获得认证

立即开始
广告
© . All rights reserved.