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

mysqlmysqli database

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

mysql> create table DemoTable
(
   CSV_Value varchar(200)
);
Query OK, 0 rows affected (0.81 sec)

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

mysql> insert into DemoTable values('10,20,50,80');
Query OK, 1 row affected (0.11 sec)
mysql> insert into DemoTable values('100,21,51,43');
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable values('1,56,103,1090');
Query OK, 1 row affected (0.26 sec)

以下是使用 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)

相关文章