提取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)
广告