Freigeben über


DTSFileSystemOperation Enumeration

Definition

Gibt den auszuführenden Dateisystemvorgang an.

public enum class DTSFileSystemOperation
public enum DTSFileSystemOperation
type DTSFileSystemOperation = 
Public Enum DTSFileSystemOperation
Vererbung
DTSFileSystemOperation

Felder

CopyDirectory 6

Mit FileSystemTask wird ein Verzeichnis kopiert. Sowohl IsDestinationPathVariable als auch IsSourcePathVariable müssen festgelegt werden.

CopyFile 0

Mit FileSystemTask wird eine Datei kopiert. Sowohl IsDestinationPathVariable als auch IsSourcePathVariable müssen festgelegt werden.

CreateDirectory 5

Mit FileSystemTask wird ein Verzeichnis erstellt. IsSourcePathVariable muss festgelegt werden.

DeleteDirectory 8

Mit FileSystemTask wird ein Verzeichnis gelöscht. IsSourcePathVariable muss festgelegt werden.

DeleteDirectoryContent 9

Mit FileSystemTask wird der Inhalt eines Verzeichnisses gelöscht. IsSourcePathVariable muss festgelegt werden.

DeleteFile 2

Mit FileSystemTask wird eine Datei gelöscht. IsSourcePathVariable muss festgelegt werden.

MoveDirectory 7

Mit FileSystemTask wird ein Verzeichnis verschoben. Sowohl IsDestinationPathVariable als auch IsSourcePathVariable müssen festgelegt werden.

MoveFile 1

Mit FileSystemTask wird eine Datei verschoben. Sowohl IsDestinationPathVariable als auch IsSourcePathVariable müssen festgelegt werden.

RenameFile 3

Mit FileSystemTask wird eine Datei umbenannt. Sowohl IsDestinationPathVariable als auch IsSourcePathVariable müssen festgelegt werden.

SetAttributes 4

Mit FileSystemTask werden die Attribute einer Datei oder eines Verzeichnisses festgelegt. Sowohl IsDestinationPathVariable als auch IsSourcePathVariable müssen festgelegt werden.

Beispiele

Im folgenden Codebeispiel wird ein FileSystemTask Paket als Executable Paket erstellt. Der FileSystemTask Testordner, der zwei Unterordner und eine .txt Datei enthält, wird in einen anderen Ordner kopiert. Der Ordner und Unterordner werden kopiert, da die auszuführende Aktion, wie durch die Operation Eigenschaft angegeben, auf CopyDirectory" festgelegt ist.

using System;  
using System.Collections.Generic;  
using System.Text;  
using Microsoft.SqlServer.Dts.Runtime;  
using Microsoft.SqlServer.Dts.Tasks.FileSystemTask;  

namespace FileSystemTask_API  
{  
    class Program  
    {  
        static void Main(string[] args)  
        {  
            String sourceDir = @"C:\TestFolder";  
            String destDir = @"C:\MyNewTestFolder";  

            Package pkg = new Package();  
            Executable exec1 = pkg.Executables.Add("STOCK:FileSystemTask");  
            TaskHost th = exec1 as TaskHost;  

            // Show how to set properties using the TaskHost Properties.  
            // Set the properties to copy an existing folder, which contains two subfolders  
            // and a .txt file, to another existing folder on the C:\ drive.  

            // The source or destination files are not in a variable, so set   
            // IsSourcePathVariable and IsDestinationPathVariable to false.  
            th.Properties["IsSourcePathVariable"].SetValue(th, false);  
            th.Properties["IsDestinationPathVariable"].SetValue(th, false);  

            // Create the File connection manager for the source.  
            ConnectionManager cm = pkg.Connections.Add("FILE");  
            cm.Name = "The FILE connection manager";  
            cm.ConnectionString = sourceDir;  
            cm.Properties["FileUsageType"].SetValue(cm, DTSFileConnectionUsageType.FolderExists);  

            // Create the File connection manager for the destination.  
            ConnectionManager cmdest = pkg.Connections.Add("FILE");  
            cmdest.Name = "The destination FILE connection manager";  
            cmdest.ConnectionString = destDir;  
            cmdest.Properties["FileUsageType"].SetValue(cmdest, DTSFileConnectionUsageType.FolderExists);  

            // Set the source property and destination properties  
            // for the task.  
            th.Properties["Source"].SetValue(th, cm.Name);  
            th.Properties["Destination"].SetValue(th, cmdest.Name);  

            // The operation to perform is to copy all the files and  
             // subfolders in a folder.  
            // Do not overwrite the destination information   
            // if it exists.  
            th.Properties["Operation"].SetValue(th, DTSFileSystemOperation.CopyDirectory);  
            th.Properties["OperationName"].SetValue(th, "Copy TestFolder");  
            th.Properties["OverwriteDestinationFile"].SetValue(th, false);  

            // Set the attribute of the folder to be read-only.  
            th.Properties["Attributes"].SetValue(th, DTSFileSystemAttributes.ReadOnly);  
            // Multiple attributes can be set. The next line of code,  
            // commented out, shows how to do that.  
            //th.Properties["Attributes"].SetValue(th, DTSFileSystemAttributes.ReadOnly | DTSFileSystemAttributes.Hidden);  

            // Run the task and copy the folder.  
            DTSExecResult result = pkg.Execute();  
        }  
    }  
}  
Imports System  
Imports System.Collections.Generic  
Imports System.Text  
Imports Microsoft.SqlServer.Dts.Runtime  
Imports Microsoft.SqlServer.Dts.Tasks.FileSystemTask  

Namespace FileSystemTask_API  
    Class Program  
        Shared  Sub Main(ByVal args() As String)  
            Dim sourceDir As String =  "C:\TestFolder"   
            Dim destDir As String =  "C:\MyNewTestFolder"   

            Dim pkg As Package =  New Package()   
            Dim exec1 As Executable =  pkg.Executables.Add("STOCK:FileSystemTask")   
            Dim th As TaskHost =  exec1 as TaskHost   

            ' Show how to set properties using the TaskHost Properties.  
            ' Set the properties to copy an existing folder, which contains two subfolders  
            ' and a .txt file, to another existing folder on the C:\ drive.  

            ' The source or destination files are not in a variable, so set   
            ' IsSourcePathVariable and IsDestinationPathVariable to false.  
            th.Properties("IsSourcePathVariable").SetValue(th, False)  
            th.Properties("IsDestinationPathVariable").SetValue(th, False)  

            ' Create the File connection manager for the source.  
            Dim cm As ConnectionManager =  pkg.Connections.Add("FILE")   
            cm.Name = "The FILE connection manager"  
            cm.ConnectionString = sourceDir  
            cm.Properties("FileUsageType").SetValue(cm, DTSFileConnectionUsageType.FolderExists)  

            ' Create the File connection manager for the destination.  
            Dim cmdest As ConnectionManager =  pkg.Connections.Add("FILE")   
            cmdest.Name = "The destination FILE connection manager"  
            cmdest.ConnectionString = destDir  
            cmdest.Properties("FileUsageType").SetValue(cmdest, DTSFileConnectionUsageType.FolderExists)  

            ' Set the source property and destination properties  
            ' for the task.  
            th.Properties("Source").SetValue(th, cm.Name)  
            th.Properties("Destination").SetValue(th, cmdest.Name)  

            ' The operation to perform is to copy all the files and  
             ' subfolders in a folder.  
            ' Do not overwrite the destination information   
            ' if it exists.  
            th.Properties("Operation").SetValue(th, DTSFileSystemOperation.CopyDirectory)  
            th.Properties("OperationName").SetValue(th, "Copy TestFolder")  
            th.Properties("OverwriteDestinationFile").SetValue(th, False)  

            ' Set the attribute of the folder to be read-only.  
            th.Properties("Attributes").SetValue(th, DTSFileSystemAttributes.ReadOnly)  
            ' Multiple attributes can be set. The next line of code,  
            ' commented out, shows how to do that.  
            'th.Properties["Attributes"].SetValue(th, DTSFileSystemAttributes.ReadOnly | DTSFileSystemAttributes.Hidden);  

            ' Run the task and copy the folder.  
            Dim result As DTSExecResult =  pkg.Execute()   
        End Sub  
    End Class  
End Namespace  

Gilt für: