Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(SQL Server) Directory Existence CheckHow to test if a directory exists on an FTP server. A good way to check to see if a directory already exists is to try to "cd" to that remote directory by calling ChangeRemoteDir. If it succeeds, then the directory exists. If not, then it does not exist. An alternative method is to set the ListPattern = "*" and then iterate over the files/directories, looking for the directory.
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- This example requires the Chilkat API to have been previously unlocked. -- See Global Unlock Sample for sample code. DECLARE @ftp int -- Use "Chilkat_9_5_0.Ftp2" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Ftp2', @ftp OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END EXEC sp_OASetProperty @ftp, 'Hostname', 'ftp.example.com' EXEC sp_OASetProperty @ftp, 'Username', 'login' EXEC sp_OASetProperty @ftp, 'Password', 'password' -- Connect and login to the FTP server. DECLARE @success int EXEC sp_OAMethod @ftp, 'Connect', @success OUT IF @success <> 1 BEGIN EXEC sp_OAGetProperty @ftp, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @ftp RETURN END -- Does the "temp" directory exist? DECLARE @dirExists int EXEC sp_OAMethod @ftp, 'ChangeRemoteDir', @dirExists OUT, '/temp' IF @dirExists = 1 BEGIN PRINT 'Yes, the temp directory exists.' -- Yes, it exists. Restore the current remote dir: EXEC sp_OAMethod @ftp, 'ChangeRemoteDir', @success OUT, '..' IF @success <> 1 BEGIN EXEC sp_OAGetProperty @ftp, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @ftp RETURN END END -- Alternatively, you may set the ListPattern = "*" and -- look for the directory: EXEC sp_OASetProperty @ftp, 'ListPattern', '*' DECLARE @i int DECLARE @n int EXEC sp_OAMethod @ftp, 'GetDirCount', @n OUT IF @n < 0 BEGIN -- Failed to get directory listing based on ListPattern EXEC sp_OAGetProperty @ftp, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @ftp RETURN END IF @n > 0 BEGIN SELECT @i = 0 WHILE @i <= @n - 1 BEGIN DECLARE @isDir int EXEC sp_OAMethod @ftp, 'GetIsDirectory', @isDir OUT, @i IF @isDir = 1 BEGIN DECLARE @fname nvarchar(4000) EXEC sp_OAMethod @ftp, 'GetFilename', @fname OUT, @i IF @fname = 'temp' BEGIN PRINT 'Found temp directory!' EXEC sp_OAMethod @ftp, 'Disconnect', @success OUT EXEC @hr = sp_OADestroy @ftp RETURN END END SELECT @i = @i + 1 END END EXEC sp_OAMethod @ftp, 'Disconnect', @success OUT EXEC @hr = sp_OADestroy @ftp END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.