从完整路径解析文件名和路径

Don*_*Don 29 t-sql sql-server

我需要使用SQL Query从完整路径解析文件名和文件路径.

例如.Fullpath - \SERVER\D $\EXPORTFILES\EXPORT001.csv

FileName        Path
EXPORT001.csv   \\SERVER\D$\EXPORTFILES\
Run Code Online (Sandbox Code Playgroud)

Age*_*SQL 60

用这个 -

DECLARE @full_path VARCHAR(1000)
SET @full_path = '\\SERVER\D$\EXPORTFILES\EXPORT001.csv'

SELECT LEFT(@full_path,LEN(@full_path) - charindex('\',reverse(@full_path),1) + 1) [path], 
       RIGHT(@full_path, CHARINDEX('\', REVERSE(@full_path)) -1)  [file_name]
Run Code Online (Sandbox Code Playgroud)

  • 为什么不呢:右(YOUR_PATH,CHARINDEX('\',REVERSE(YOUR_PATH))-1) (23认同)
  • @StefanSteiger他做了......他提供了2个字段而不是1个字段 (2认同)

Mar*_*ram 17

我做了很多ETL工作,我正在寻找一个我可以使用的函数,并且qub1n的 解决方案非常好,除了没有反斜杠的值.这是对qub1n解决方案的一点调整,它将处理没有反斜杠的字符串:

Create FUNCTION fnGetFileName
(
    @fullpath nvarchar(260)
) 
RETURNS nvarchar(260)
AS
BEGIN
    IF(CHARINDEX('\', @fullpath) > 0)
       SELECT @fullpath = RIGHT(@fullpath, CHARINDEX('\', REVERSE(@fullpath)) -1)
       RETURN @fullpath
END
Run Code Online (Sandbox Code Playgroud)

样品:

    SELECT [dbo].[fnGetFileName]('C:\Test\New Text Document.txt') --> New Text Document.txt
    SELECT [dbo].[fnGetFileName]('C:\Test\Text Docs\New Text Document.txt') --> New Text Document.txt
    SELECT [dbo].[fnGetFileName]('New Text Document.txt') --> New Text Document.txt
    SELECT [dbo].[fnGetFileName]('\SERVER\D$\EXPORTFILES\EXPORT001.csv') --> EXPORT001.csv
Run Code Online (Sandbox Code Playgroud)

这是SqlFiddle 的链接

  • 对我来说这是解决方案!;) (2认同)

sms*_*247 5

这是最简单的方法

DECLARE @full_path VARCHAR(1000)
SET @full_path = '\\SERVER\D$\EXPORTFILES\EXPORT001.csv'
SELECT  LEFT(@full_path, LEN(@full_path) - CHARINDEX('\', REVERSE(@full_path)) - 1),
        RIGHT(@full_path, CHARINDEX('\', REVERSE(@full_path)) - 1)
Run Code Online (Sandbox Code Playgroud)


Tom*_*bes 5

根据Stefan Steiger的评论回答:

Create FUNCTION GetFileName
(
 @fullpath nvarchar(260)
) 
RETURNS nvarchar(260)
AS
BEGIN
DECLARE @charIndexResult int
SET @charIndexResult = CHARINDEX('\', REVERSE(@fullpath))

IF @charIndexResult = 0
    RETURN NULL 

RETURN RIGHT(@fullpath, @charIndexResult -1)
END
GO
Run Code Online (Sandbox Code Playgroud)

测试代码:

DECLARE @fn nvarchar(260)

EXEC @fn = dbo.GetFileName 'AppData\goto\image.jpg'
PRINT @fn -- prints image.jpg

EXEC @fn = dbo.GetFileName 'c:\AppData\goto\image.jpg'
PRINT @fn -- prints image.jpg

EXEC @fn = dbo.GetFileName 'image.jpg'
PRINT @fn -- prints NULL
Run Code Online (Sandbox Code Playgroud)