提取MySQL中列值中间部分(用连字符包围)并在新列中显示?


使用SUBSTR()方法提取用连字符包围的列值中间部分,例如,“11-84848-11”。

让我们先创建一个表:

mysql> create table DemoTable
-> (
-> Number varchar(100),
-> Number1 varchar(100)
-> );
Query OK, 0 rows affected (0.56 sec)

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

mysql> insert into DemoTable(Number) values('11-84848-11');
Query OK, 1 row affected (0.15 sec)

mysql> insert into DemoTable(Number) values('22-99999-22');
Query OK, 1 row affected (0.13 sec)

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

mysql> select *from DemoTable;

输出

这将产生以下输出:

+-------------+---------+
| Number      | Number1 |
+-------------+---------+
| 11-84848-11 | NULL    |
| 22-99999-22 | NULL    |
+-------------+---------+
2 rows in set (0.00 sec)

以下是提取MySQL中列值中间部分的查询:

mysql> update DemoTable
-> set Number1=SUBSTR(Number,4,5);
Query OK, 2 rows affected (0.19 sec)
Rows matched: 2 Changed: 2 Warnings: 0

让我们再次检查表记录:

mysql> select *from DemoTable;

输出

这将产生以下输出:

+-------------+---------+
| Number      | Number1 |
+-------------+---------+
| 11-84848-11 | 84848   |
| 22-99999-22 | 99999   |
+-------------+---------+
2 rows in set (0.00 sec)

更新于:2020年6月30日

196 次浏览

启动你的职业生涯

完成课程获得认证

开始学习
广告