DTSXMLOperation Enumeração
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
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.