Compartilhar via


DTSXMLOperation Enumeração

Definição

Especifica as operações usadas durante o trabalho com documentos XML.

public enum class DTSXMLOperation
public enum DTSXMLOperation
type DTSXMLOperation = 
Public Enum DTSXMLOperation
Herança
DTSXMLOperation

Campos

Diff 4

Compara dois documentos XML. Usando o documento XML de origem como documento base, a operação Diff o compara a outro documento XML, detecta as diferenças e as grava em um documento DiffGram XML. Essa operação inclui propriedades para personalizar a comparação.

Merge 3

Mescla dois documentos XML. Usando o documento XML de origem como o documento base, o conteúdo de um segundo documento é mesclado ao documento base. A operação pode especificar um local de mesclagem no documento.

Patch 5

Aplica a saída da operação Diff (um documento DiffGram) a um documento XML para criar um novo documento pai que possa incluir o conteúdo do documento DiffGram.

Validate 0

Valida o documento XML com base em um DTD (definição de tipo de documento) ou XSD (definição de esquema XML).

XPATH 2

Executa consultas e avaliações de XPath.

XSLT 1

Executa transformações de XSL em documentos XML.

Exemplos

O exemplo de código a seguir mostra essa enumeração sendo usada para definir o OperationType direito após a criação da tarefa.

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

namespace XMLTask_API  
{  
    class Program  
        {  
        static void Main(string[] args)  
                {  
                        // Set up the objects and tasks.  
                        Package pkg = new Package();  
                        Executable exec1 = pkg.Executables.Add("STOCK:XMLTask");  
                        TaskHost th = exec1 as TaskHost;  
                        // You can cast the InnerObject to the XmlTask, but it is advised   
                        // that you work with tasks through the TaskHost and its Properties.  
                        // XMLTask myTask = th.InnerObject as XMLTask;  

                        // Create a variable and a FILE connection manager to books.xml.  
                        Variable resultVar = pkg.Variables.Add("resultVariable", false, "", "Variable for the result");  
                        ConnectionManager connMgr = pkg.Connections.Add("FILE");  
                        connMgr.Name = "XMLConnectionManager";  
                        // The file, Books.xml, is stored on the C:\ drive.  
                        connMgr.ConnectionString = @"c:\books.xml";  

                        // Set the XMLTask properties.  
                        // The first property to set is the OperationType. Depending on the  
                        // OperationType, different properties are valid.  
                        // The operation type in this example is VALIDATE.  
                        th.Properties["OperationType"].SetValue(th, DTSXMLOperation.Validate);  
                        th.Properties["SourceType"].SetValue(th, DTSXMLSourceType.FileConnection);  
                        th.Properties["Source"].SetValue(th, connMgr.Name);  
                        th.Properties["OverwriteDestination"].SetValue(th, true);  
                        th.Properties["SaveOperationResult"].SetValue(th, true);  
                        th.Properties["DestinationType"].SetValue(th, DTSXMLSaveResultTo.Variable);  
                        th.Properties["Destination"].SetValue(th, resultVar.Name);  
                        th.Properties["SecondOperandType"].SetValue(th, DTSXMLSourceType.DirectInput);  
                        th.Properties["SecondOperand"].SetValue(th, "<x></x>");  
                        th.Properties["ValidationType"].SetValue(th, DTSXMLValidationType.DTD);  
                        th.Properties["FailOnValidationFaile"].SetValue(th, true);  
                        DTSExecResult valResults = pkg.Validate(pkg.Connections, pkg.Variables, null, null);  
                        Console.WriteLine("RESULTS: {0}", valResults);  
                }  
        }  
}  

Saída de exemplo:

RESULTADOS: Êxito

Comentários

Essa operação determina quais outras propriedades na XMLTask classe são válidas. Por exemplo, se a operação escolhida for XPATH, as propriedades PutResultInOneNode e XPathOperation serão usadas. Quando a operação estiver Validate, o FailOnValidationFail sinalizador estará disponível. Geralmente, essa é a primeira propriedade definida no código, apenas para que você possa ver imediatamente qual tarefa está XMLTask sendo executada.

Aplica-se a