在MySQL中选择逗号分隔列表的第一个元素?

要选择逗号分隔列表的第一个元素,可以使用SUBSTRING_INDEX()。让我们首先创建一个表:

mysql> create table DemoTable
(
   CSV_Value varchar(200)
);

以下是使用insert命令在表中插入一些记录的查询。我们以逗号分隔的整数列表的形式插入了记录:

mysql> insert into DemoTable values('10,20,50,80');
mysql> insert into DemoTable values('100,21,51,43');
mysql> insert into DemoTable values('1,56,103,1090');

以下是使用select命令显示表中记录的查询:

mysql> select *from DemoTable;

这将产生以下输出:

+---------------+
| CSV_Value     |
+---------------+
| 10,20,50,80   |
| 100,21,51,43  |
| 1,56,103,1090 |
+---------------+
3 rows in set (0.00 sec)

以下是选择逗号分隔列表的第一个元素的查询:

mysql> select SUBSTRING_INDEX(CSV_Value,',',1) AS FIRST_ELEMENT from DemoTable;

这将产生以下输出。每个列表的第一个元素显示在此处:

+---------------+
| FIRST_ELEMENT |
+---------------+
| 10            |
| 100           |
| 1             |
+---------------+
3 rows in set (0.03 sec)