旃麒雅 发表于 2018-10-21 14:21:21

带通配符,查找 指定目录下文件的SQL存储过程

--查找指定文件夹(目录)下的文件。  
ALTER PROCEDURE .
  
@Path nvarchar(1000) --搜索路径。
  
      --表示【文件夹路径】必须以'\'结尾;
  
      --表示【文件路径】不能以\结尾。(文件名可带通配符)
  
,@FileS nvarchar(MAX) OUTPUT --返回 找到的 文件名串
  
,@Depth int=1 --搜索[文件夹]深度。不为1,将搜索[子文件夹]。0全部目录,1 第一级目录,2 第二级目录 依此类推
  
,@FG nvarchar(10)=NULL --文件名串的 分隔符;默认char(13)
  
AS
  
BEGIN
  
      SET NOCOUNT ON;
  
      SET @FG=ISNULL(@FG,char(13));--分隔符;默认char(13)
  
      IF @Depth0 AND SUBSTRING(@Path,@i,1)'\' BEGIN   --'
  
                        SET @i=@i-1;
  
                        END;
  
                IF @i>0 BEGIN
  
                        --截取 文件名
  
                        SET @FileName=SUBSTRING(@Path,@i+1,LEN(@Path));
  
                        SET @Path =SUBSTRING(@Path,1,@i-1);
  
                        --转换通配符
  
                        SET @FileName=replace(@FileName,'*','%');
  
                        SET @FileName=replace(@FileName,'?','_');
  
                        END;
  
                END;
  
      --print '@Path='+ISNULL(@Path,'')+'@FileName='+ISNULL(@FileName,'');
  

  
      insert @Tab exec master..xp_dirtree @Path
  
      ,@Depth --查找深度:0全部目录,1 第一级目录,2 第二级目录 依此类推
  
      ,1 ;--0文件夹,非0:文件夹和文件名
  

  
      --删除不匹配 记录
  
      IF ISNULL(@FileName,'')'' BEGIN
  
                --select from @Tab WHERE =1 AND like @FileName ;
  
                DELETE @Tab WHERE 1 OR not like @FileName;
  
                END;
  
      ELSE DELETE @Tab WHERE 1;
  

  
      --拼装 文件名串;加 分隔符@FG
  
      SET @FileS='';
  
      SELECT @FileS=@FileS+@FG+ISNULL(,'') FROM @Tab;
  
      IF @FileS''BEGIN--去除首位 分隔符@FG
  
                IF SUBSTRING(@FileS,1,LEN(@FG))=@FG BEGIN ;
  
                        SET @FileS=SUBSTRING(@FileS,LEN(@FG)+1,LEN(@FileS));
  
                        END;
  
                END;
  
END1:
  
      --print '@FileS='+@FileS;
  
      --select from @Tab;
  
END


页: [1]
查看完整版本: 带通配符,查找 指定目录下文件的SQL存储过程