TransPublication Clase

Definición

Representa una publicación transaccional.

public ref class TransPublication sealed : Microsoft::SqlServer::Replication::Publication
public sealed class TransPublication : Microsoft.SqlServer.Replication.Publication
type TransPublication = class
    inherit Publication
Public NotInheritable Class TransPublication
Inherits Publication
Herencia

Ejemplos

Este ejemplo crea una publicación transaccional.

// Set the Publisher, publication database, and publication names.
string publicationName = "AdvWorksProductTran";
string publicationDbName = "AdventureWorks2012";
string publisherName = publisherInstance;

ReplicationDatabase publicationDb;
TransPublication publication;

// Create a connection to the Publisher using Windows Authentication.
ServerConnection conn;
conn = new ServerConnection(publisherName);


try
{
    // Connect to the Publisher.
    conn.Connect();

    // Enable the AdventureWorks2012 database for transactional publishing.
    publicationDb = new ReplicationDatabase(publicationDbName, conn);

    // If the database exists and is not already enabled, 
    // enable it for transactional publishing.
    if (publicationDb.LoadProperties())
    {
        if (!publicationDb.EnabledTransPublishing)
        {
            publicationDb.EnabledTransPublishing = true;
        }

        // If the Log Reader Agent does not exist, create it.
        if (!publicationDb.LogReaderAgentExists)
        {
            // Specify the Windows account under which the agent job runs.
            // This account will be used for the local connection to the 
            // Distributor and all agent connections that use Windows Authentication.
            publicationDb.LogReaderAgentProcessSecurity.Login = winLogin;
            publicationDb.LogReaderAgentProcessSecurity.Password = winPassword;

            // Explicitly set authentication mode for the Publisher connection
            // to the default value of Windows Authentication.
            publicationDb.LogReaderAgentPublisherSecurity.WindowsAuthentication = true;

            // Create the Log Reader Agent job.
            publicationDb.CreateLogReaderAgent();
        }
    }
    else
    {
        throw new ApplicationException(String.Format(
            "The {0} database does not exist at {1}.",
            publicationDb, publisherName));
    }

    // Set the required properties for the transactional publication.
    publication = new TransPublication();
    publication.ConnectionContext = conn;
    publication.Name = publicationName;
    publication.DatabaseName = publicationDbName;

    // Specify a transactional publication (the default).
    publication.Type = PublicationType.Transactional;

    // Activate the publication so that we can add subscriptions.
    publication.Status = State.Active;

    // Enable push and pull subscriptions and independent Distribition Agents.
    publication.Attributes |= PublicationAttributes.AllowPull;
    publication.Attributes |= PublicationAttributes.AllowPush;
    publication.Attributes |= PublicationAttributes.IndependentAgent;

    // Specify the Windows account under which the Snapshot Agent job runs.
    // This account will be used for the local connection to the 
    // Distributor and all agent connections that use Windows Authentication.
    publication.SnapshotGenerationAgentProcessSecurity.Login = winLogin;
    publication.SnapshotGenerationAgentProcessSecurity.Password = winPassword;

    // Explicitly set the security mode for the Publisher connection
    // Windows Authentication (the default).
    publication.SnapshotGenerationAgentPublisherSecurity.WindowsAuthentication = true;

    if (!publication.IsExistingObject)
    {
        // Create the transactional publication.
        publication.Create();

        // Create a Snapshot Agent job for the publication.
        publication.CreateSnapshotAgent();
    }
    else
    {
        throw new ApplicationException(String.Format(
            "The {0} publication already exists.", publicationName));
    }
}

catch (Exception ex)
{
    // Implement custom application error handling here.
    throw new ApplicationException(String.Format(
        "The publication {0} could not be created.", publicationName), ex);
}
finally
{
    conn.Disconnect();
}
' Set the Publisher, publication database, and publication names.
Dim publicationName As String = "AdvWorksProductTran"
Dim publicationDbName As String = "AdventureWorks2012"
Dim publisherName As String = publisherInstance

Dim publicationDb As ReplicationDatabase
Dim publication As TransPublication

' Create a connection to the Publisher using Windows Authentication.
Dim conn As ServerConnection
conn = New ServerConnection(publisherName)

Try
    ' Connect to the Publisher.
    conn.Connect()

    ' Enable the AdventureWorks2012 database for transactional publishing.
    publicationDb = New ReplicationDatabase(publicationDbName, conn)

    ' If the database exists and is not already enabled, 
    ' enable it for transactional publishing.
    If publicationDb.LoadProperties() Then
        If Not publicationDb.EnabledTransPublishing Then
            publicationDb.EnabledTransPublishing = True
        End If

        ' If the Log Reader Agent does not exist, create it.
        If Not publicationDb.LogReaderAgentExists Then
            ' Specify the Windows account under which the agent job runs.
            ' This account will be used for the local connection to the 
            ' Distributor and all agent connections that use Windows Authentication.
            publicationDb.LogReaderAgentProcessSecurity.Login = winLogin
            publicationDb.LogReaderAgentProcessSecurity.Password = winPassword

            ' Explicitly set authentication mode for the Publisher connection
            ' to the default value of Windows Authentication.
            publicationDb.LogReaderAgentPublisherSecurity.WindowsAuthentication = True

            ' Create the Log Reader Agent job.
            publicationDb.CreateLogReaderAgent()
        End If
    Else
        Throw New ApplicationException(String.Format( _
         "The {0} database does not exist at {1}.", _
         publicationDb, publisherName))
    End If

    ' Set the required properties for the transactional publication.
    publication = New TransPublication()
    publication.ConnectionContext = conn
    publication.Name = publicationName
    publication.DatabaseName = publicationDbName

    ' Specify a transactional publication (the default).
    publication.Type = PublicationType.Transactional

    'Enable push and pull subscriptions and independent Distribition Agents.
    publication.Attributes = _
    publication.Attributes Or PublicationAttributes.AllowPull
    publication.Attributes = _
    publication.Attributes Or PublicationAttributes.AllowPush
    publication.Attributes = _
    publication.Attributes Or PublicationAttributes.IndependentAgent

    ' Activate the publication so that we can add subscriptions.
    publication.Status = State.Active

    ' Specify the Windows account under which the Snapshot Agent job runs.
    ' This account will be used for the local connection to the 
    ' Distributor and all agent connections that use Windows Authentication.
    publication.SnapshotGenerationAgentProcessSecurity.Login = winLogin
    publication.SnapshotGenerationAgentProcessSecurity.Password = winPassword

    ' Explicitly set the security mode for the Publisher connection
    ' Windows Authentication (the default).
    publication.SnapshotGenerationAgentPublisherSecurity.WindowsAuthentication = True

    If Not publication.IsExistingObject Then
        ' Create the transactional publication.
        publication.Create()

        ' Create a Snapshot Agent job for the publication.
        publication.CreateSnapshotAgent()
    Else
        Throw New ApplicationException(String.Format( _
            "The {0} publication already exists.", publicationName))
    End If
Catch ex As Exception
    ' Implement custom application error handling here.
    Throw New ApplicationException(String.Format( _
        "The publication {0} could not be created.", publicationName), ex)
Finally
    conn.Disconnect()
End Try

En este ejemplo se elimina una publicación transaccional.

// Define the Publisher, publication database, 
// and publication names.
string publisherName = publisherInstance;
string publicationName = "AdvWorksProductTran";
string publicationDbName = "AdventureWorks2012";

TransPublication publication;
ReplicationDatabase publicationDb;

// Create a connection to the Publisher 
// using Windows Authentication.
ServerConnection conn = new ServerConnection(publisherName);

try
{
    conn.Connect();

    // Set the required properties for the transactional publication.
    publication = new TransPublication();
    publication.ConnectionContext = conn;
    publication.Name = publicationName;
    publication.DatabaseName = publicationDbName;

    // Delete the publication, if it exists and has no subscriptions.
    if (publication.LoadProperties() && !publication.HasSubscription)
    {
        publication.Remove();
    }
    else
    {
        // Do something here if the publication does not exist
        // or has subscriptions.
        throw new ApplicationException(String.Format(
            "The publication {0} could not be deleted. " +
            "Ensure that the publication exists and that all " +
            "subscriptions have been deleted.",
            publicationName, publisherName));
    }

    // If no other transactional publications exists,
    // disable publishing on the database.
    publicationDb = new ReplicationDatabase(publicationDbName, conn);
    if (publicationDb.LoadProperties())
    {
        if (publicationDb.TransPublications.Count == 0)
        {
            publicationDb.EnabledTransPublishing = false;
        }
    }
    else
    {
        // Do something here if the database does not exist.
        throw new ApplicationException(String.Format(
            "The database {0} does not exist on {1}.",
            publicationDbName, publisherName));
    }
}
catch (Exception ex)
{
    // Implement application error handling here.
    throw new ApplicationException(String.Format(
        "The publication {0} could not be deleted.",
        publicationName), ex);
}
finally
{
    conn.Disconnect();
}
' Define the Publisher, publication database, 
' and publication names.
Dim publisherName As String = publisherInstance
Dim publicationName As String = "AdvWorksProductTran"
Dim publicationDbName As String = "AdventureWorks2012"

Dim publication As TransPublication
Dim publicationDb As ReplicationDatabase

' Create a connection to the Publisher 
' using Windows Authentication.
Dim conn As ServerConnection = New ServerConnection(publisherName)

Try
    conn.Connect()

    ' Set the required properties for the transactional publication.
    publication = New TransPublication()
    publication.ConnectionContext = conn
    publication.Name = publicationName
    publication.DatabaseName = publicationDbName

    ' Delete the publication, if it exists and has no subscriptions.
    If publication.LoadProperties() And Not publication.HasSubscription Then
        publication.Remove()
    Else
        ' Do something here if the publication does not exist
        ' or has subscriptions.
        Throw New ApplicationException(String.Format( _
         "The publication {0} could not be deleted. " + _
         "Ensure that the publication exists and that all " + _
         "subscriptions have been deleted.", _
         publicationName, publisherName))
    End If

    ' If no other transactional publications exists,
    ' disable publishing on the database.
    publicationDb = New ReplicationDatabase(publicationDbName, conn)
    If publicationDb.LoadProperties() Then
        If publicationDb.TransPublications.Count = 0 Then
            publicationDb.EnabledTransPublishing = False
        End If
    Else
        ' Do something here if the database does not exist.
        Throw New ApplicationException(String.Format( _
         "The database {0} does not exist on {1}.", _
         publicationDbName, publisherName))
    End If
Catch ex As Exception
    ' Implement application error handling here.
    Throw New ApplicationException(String.Format( _
     "The publication {0} could not be deleted.", _
     publicationName), ex)
Finally
    conn.Disconnect()
End Try

Comentarios

Seguridad para subprocesos

Los miembros estáticos públicos (Shared en Microsoft Visual Basic) de este tipo son seguros para las operaciones multiproceso. No se garantiza que los miembros de instancia sean seguros para subprocesos.

Constructores

TransPublication()

Crea una nueva instancia de la clase TransPublication.

TransPublication(String, String, ServerConnection)

Crea una instancia de la clase TransPublication con las propiedades requeridas.

TransPublication(String, String, ServerConnection, Boolean)

Crea una instancia de la clase TransPublication con las propiedades requeridas e indica si se crea el trabajo del Agente de instantáneas para la publicación.

Propiedades

AltSnapshotFolder

Obtiene o establece la ubicación del archivo de instantáneas alternativo para una publicación.

(Heredado de Publication)
Attributes

Obtiene o establece los atributos de la publicación.

(Heredado de Publication)
CachePropertyChanges

Obtiene o establece si los cambios realizados en las propiedades de replicación se almacenan en memoria caché o se aplican inmediatamente.

(Heredado de ReplicationObject)
CompatibilityLevel

Obtiene o establece la versión más antigua de Microsoft SQL Server que se ejecuta en los suscriptores que puede admitir la publicación a la que se hace referencia.

(Heredado de Publication)
ConflictPolicy

Obtiene o establece la directiva de conflictos para las publicaciones con las que son compatibles las suscripciones de actualización.

ConflictRetention

Obtiene o establece el número de días que las filas de datos de conflicto se conservan en las tablas de conflictos.

(Heredado de Publication)
ConnectionContext

Obtiene o establece la conexión a una instancia de Microsoft SQL Server.

(Heredado de ReplicationObject)
ContinueOnConflict

Determina si el Agente de distribución continúa procesando los cambios después de la detección de un conflicto.

CreateSnapshotAgentByDefault

Obtiene o establece si automáticamente se agrega el trabajo del Agente de instantáneas cuando se crea la publicación.

(Heredado de Publication)
DatabaseName

Obtiene o establece el nombre de la base de datos de publicación.

(Heredado de Publication)
Description

Obtiene o establece una descripción textual de la publicación.

(Heredado de Publication)
FtpAddress

Obtiene o establece la dirección del equipo servidor del Protocolo de transferencia de archivos (FTP) para las publicaciones que permiten la inicialización de suscripciones sobre FTP.

(Heredado de Publication)
FtpLogin

Obtiene o establece el inicio de sesión que se utiliza para la conexión al servidor del Protocolo de transferencia de archivos (FTP) para las publicaciones que permiten la inicialización de suscripciones sobre FTP.

(Heredado de Publication)
FtpPassword

Establece la contraseña del inicio de sesión que se utiliza para la conexión al servidor del Protocolo de transferencia de archivos (FTP) para las publicaciones que permiten la inicialización de suscripciones sobre FTP.

(Heredado de Publication)
FtpPort

Obtiene o establece el puerto del equipo servidor del Protocolo de transferencia de archivos (FTP) para las publicaciones que permiten la inicialización de suscripciones sobre FTP.

(Heredado de Publication)
FtpSubdirectory

Obtiene o establece el subdirectorio del equipo servidor del Protocolo de transferencia de archivos (FTP) para las publicaciones que permiten la inicialización de suscripciones sobre FTP.

(Heredado de Publication)
HasSubscription

Obtiene si la publicación tiene una o más suscripciones.

(Heredado de Publication)
IsExistingObject

Obtiene si el objeto existe en el servidor.

(Heredado de ReplicationObject)
Name

Obtiene o establece el nombre de la publicación.

(Heredado de Publication)
PeerConflictDetectionEnabled

Obtiene si la detección de conflictos punto a punto se habilitó utilizando SetPeerConflictDetection(Boolean, Int32).

PeerOriginatorID

Obtiene el identificador de un nodo en una topología punto a punto; este identificador se usa para la detección de conflictos si PeerConflictDetectionEnabled está establecido en true.

PostSnapshotScript

Obtiene o establece el nombre y la ruta de acceso completa de un archivo de script de Transact-SQL que se ejecuta después de aplicar la instantánea inicial al suscriptor.

(Heredado de Publication)
PreSnapshotScript

Obtiene o establece el nombre y la ruta de acceso completa de un archivo de script de Transact-SQL que se ejecuta antes de que se aplique la instantánea inicial al suscriptor.

(Heredado de Publication)
PubId

Obtiene el valor que identifica de forma unívoca la publicación.

(Heredado de Publication)
PublisherName

Obtiene o establece el nombre del publicador que no es de SQL Server.

QueueType

Obtiene o establece el tipo de cola a usar para las publicaciones que permiten las suscripciones de actualización en cola.

ReplicateDdl

Obtiene o establece las opciones de replicación de lenguaje de definición de datos (DDL) que determinan si se replican los cambios de DDL.

(Heredado de Publication)
RetentionPeriod

Obtiene o establece la cantidad de tiempo que transcurre antes de que una suscripción expire si la suscripción no se sincroniza con la publicación.

(Heredado de Publication)
SecureFtpPassword

Establece la contraseña (como un objeto SecureString) del inicio de sesión que se utiliza para la conexión al servidor del Protocolo de transferencia de archivos (FTP) para las publicaciones que permiten la inicialización de suscripciones sobre FTP.

(Heredado de Publication)
SnapshotAgentExists

Obtiene si el trabajo de Agente SQL Server existe para generar la instantánea inicial de esta publicación.

(Heredado de Publication)
SnapshotAvailable

Obtiene si los archivos de instantánea están disponibles o no para uso en esta publicación.

SnapshotGenerationAgentProcessSecurity

Obtiene un objeto que establece la cuenta de Windows bajo la cual se ejecuta el trabajo del Agente de instantáneas.

(Heredado de Publication)
SnapshotGenerationAgentPublisherSecurity

Obtiene el contexto de seguridad utilizado por el Agente de instantáneas para la conexión al publicador.

(Heredado de Publication)
SnapshotJobId

Obtiene el identificador del trabajo del Agente de instantáneas para la publicación actual.

(Heredado de Publication)
SnapshotMethod

Obtiene o establece el formato del archivo de datos de la instantánea inicial.

(Heredado de Publication)
SnapshotSchedule

Obtiene un objeto que establece la programación para el Agente de instantáneas para la publicación actual.

(Heredado de Publication)
SqlServerName

Obtiene el nombre de la instancia de Microsoft SQL Server a la que está conectado este objeto.

(Heredado de ReplicationObject)
Status

Obtiene o establece el estado de la publicación.

(Heredado de Publication)
TransArticles

Representa los artículos de la publicación.

TransSubscriptions

Representa las suscripciones de la publicación.

Type

Obtiene o establece el tipo de publicación.

(Heredado de Publication)
UserData

Obtiene o establece una propiedad de un objeto que permite a los usuarios adjuntar sus propios datos al objeto.

(Heredado de ReplicationObject)

Métodos

BrowseSnapshotFolder(String, String)

Devuelve la ruta de acceso completa de la ubicación donde se generaron los archivos de instantánea para una suscripción concreta.

CheckValidCreation()

Comprueba la creación de replicación válida.

(Heredado de ReplicationObject)
CheckValidDefinition(Boolean)

Indica si se debe comprobar la definición válida.

(Heredado de Publication)
CommitPropertyChanges()

Envía todas las instrucciones de cambio de propiedad almacenadas en caché a la instancia de Microsoft SQL Server.

(Heredado de ReplicationObject)
CopySnapshot(String, String, String)

Copia los últimos archivos de instantánea de una suscripción concreta en una carpeta de destino.

Create()

Crea la publicación.

(Heredado de Publication)
CreateSnapshotAgent()

Crea el trabajo Agente SQL Server que se usa para generar la instantánea inicial de la publicación, si este trabajo aún no existe.

(Heredado de Publication)
Decouple()

Desacopla del servidor el objeto de replicación al que se hace referencia.

(Heredado de ReplicationObject)
EnumArticles()

Devuelve los artículos de la publicación.

(Heredado de Publication)
EnumPublicationAccesses(Boolean)

Devuelve los inicios de sesión que tienen acceso al publicador.

(Heredado de Publication)
EnumSubscriptions()

Devuelve las suscripciones que se suscriben a la publicación.

(Heredado de Publication)
GetChangeCommand(StringBuilder, String, String)

Devuelve el comando de cambio de la replicación.

(Heredado de ReplicationObject)
GetCreateCommand(StringBuilder, Boolean, ScriptOptions)

Devuelve el comando de creación de la replicación.

(Heredado de ReplicationObject)
GetDropCommand(StringBuilder, Boolean)

Devuelve el comando drop de la replicación.

(Heredado de ReplicationObject)
GrantPublicationAccess(String)

Agrega el inicio de sesión especificado a la lista de acceso a la publicación (PAL).

(Heredado de Publication)
InternalRefresh(Boolean)

Inicia una actualización interna de la replicación.

(Heredado de ReplicationObject)
Load()

Carga las propiedades de un objeto existente desde el servidor.

(Heredado de ReplicationObject)
LoadProperties()

Carga las propiedades de un objeto existente desde el servidor.

(Heredado de ReplicationObject)
MakePullSubscriptionWellKnown(String, String, SubscriptionSyncType, TransSubscriberType)

Registra una suscripción de extracción en el publicador.

MakePullSubscriptionWellKnown(String, String, SubscriptionSyncType, TransSubscriberType, Boolean)

Representa una publicación transaccional.

PostTracerToken()

Envía un token de seguimiento al registro del publicador para comenzar el proceso de determinación de la latencia.

Refresh()

Vuelve a cargar las propiedades del objeto.

(Heredado de ReplicationObject)
RefreshSubscriptions()

Actualiza todas las suscripciones a una publicación para incluir cualquier artículo agregado recientemente.

ReinitializeAllSubscriptions()

Marca todas las suscripciones a la publicación para reinicialización.

ReinitializeAllSubscriptions(Boolean)

Marca todas las suscripciones a la publicación para reinicialización, con la posibilidad de invalidar una instantánea existente.

Remove()

Quita una publicación existente.

(Heredado de Publication)
Remove(Boolean)

Quita una publicación existente aun cuando no se pueda tener acceso al distribuidor.

(Heredado de Publication)
RemovePullSubscription(String, String)

Quita el registro de una suscripción de extracción del publicador.

ReplicateUserDefinedScript(String)

Replica la ejecución de un script definido por el usuario en los suscriptores de una publicación especificada.

(Heredado de Publication)
RevokePublicationAccess(String)

Quita el inicio de sesión especificado de la lista de acceso a la publicación (PAL).

(Heredado de Publication)
Script(ScriptOptions)

Genera un script de Transact-SQL que se puede usar para volver a crear la publicación según lo especificado por las opciones de script.

(Heredado de Publication)
SetPeerConflictDetection(Boolean, Int32)

Habilita o deshabilita la detección de conflictos para un nodo en una topología punto a punto.

StartSnapshotGenerationAgentJob()

Inicia el trabajo que genera la instantánea inicial para la publicación.

(Heredado de Publication)
StopSnapshotGenerationAgentJob()

Intenta detener un trabajo del Agente de instantáneas en ejecución.

(Heredado de Publication)
ValidatePublication(ValidationOption, ValidationMethod, Boolean)

Invoca la validación de publicación insertada para todas las suscripciones.

ValidateSubscriptions(String[], String[], ValidationOption, ValidationMethod, Boolean)

Invoca la validación de publicación insertada para la suscripción especificada.

Se aplica a

Consulte también