MySQL查询用目录链接替换最后一个/列中的字符串?

为此,请使用substring_index()方法。让我们首先创建一个表-

mysql> create table DemoTable
   -> (
   -> FolderName varchar(100),
   -> FolderLocation varchar(200)
   -> );

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

mysql> insert into DemoTable values('CProgram','C:/AllPrograms/.....');

mysql> insert into DemoTable values('Images','E:/MyImage/home/garbage');

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

mysql> select *from DemoTable;

输出结果

+------------+-------------------------+
| FolderName | FolderLocation          |
+------------+-------------------------+
| CProgram   | C:/AllPrograms/.....    |
| Images     | E:/MyImage/home/garbage |
+------------+-------------------------+
2 rows in set (0.00 sec)

这是用目录链接替换列中最后一个/后面的字符串的查询-

mysql> UPDATE DemoTable SET FolderLocation = CONCAT(LEFT(FolderLocation , CHAR_LENGTH(FolderLocation ) - CHAR_LENGTH(SUBSTRING_INDEX(FolderLocation , '/', -1))),FolderName);
Rows matched: 2  Changed: 2 Warnings: 0

让我们再次检查表记录-

mysql> select *from DemoTable;

输出结果

+------------+-------------------------+
| FolderName | FolderLocation          |
+------------+-------------------------+
| CProgram   | C:/AllPrograms/CProgram |
| Images     | E:/MyImage/home/Images  |
+------------+-------------------------+
2 rows in set (0.00 sec)