MySQL中是否有等效的PHP basename()?

如果给定一个包含文件路径的字符串,PHPbasename()函数将返回文件的基本名称。要在MySQL中获得等效功能,可以使用SUBSTRING_INDEX()。让我们首先创建一个表-

mysql> create table DemoTable
   -> (
   -> Location varchar(200)
   -> );

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

mysql> insert into DemoTable values('C:\\Web\\Sum.java');

mysql> insert into DemoTable values('E:\\WebDevelopment\\Image1.png');

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

mysql> select *from DemoTable;

输出结果

+------------------------------+
| Location                     |
+------------------------------+
| C:\Web\Sum.java              |
| E:\WebDevelopment\Image1.png |
+------------------------------+
2 rows in set (0.00 sec)

以下是与basename()MySQL中的等效项一起使用的查询,并获取basename()函数返回的内容,即文件的基本名称-

mysql> select Location,
   -> SUBSTRING_INDEX(Location,'\\', -1) AS NameOfFile from DemoTable;

输出结果

+------------------------------+------------+
| Location                     | NameOfFile |
+------------------------------+------------+
| C:\Web\Sum.java              | Sum.java   |
| E:\WebDevelopment\Image1.png | Image1.png |
+------------------------------+------------+
2 rows in set (0.00 sec)