TransSubscription Classe
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.
Representa uma assinatura push de uma publicação transacional ou de instantâneo.
public ref class TransSubscription sealed : Microsoft::SqlServer::Replication::Subscription
public sealed class TransSubscription : Microsoft.SqlServer.Replication.Subscription
type TransSubscription = class
inherit Subscription
Public NotInheritable Class TransSubscription
Inherits Subscription
- Herança
Exemplos
// Define the Publisher, publication, and databases.
string publicationName = "AdvWorksProductTran";
string publisherName = publisherInstance;
string subscriberName = subscriberInstance;
string subscriptionDbName = "AdventureWorks2012Replica";
string publicationDbName = "AdventureWorks2012";
//Create a connection to the Publisher.
ServerConnection conn = new ServerConnection(publisherName);
// Create the objects that we need.
TransPublication publication;
TransSubscription subscription;
try
{
// Connect to the Publisher.
conn.Connect();
// Ensure that the publication exists and that
// it supports push subscriptions.
publication = new TransPublication();
publication.Name = publicationName;
publication.DatabaseName = publicationDbName;
publication.ConnectionContext = conn;
if (publication.IsExistingObject)
{
if ((publication.Attributes & PublicationAttributes.AllowPush) == 0)
{
publication.Attributes |= PublicationAttributes.AllowPush;
}
// Define the push subscription.
subscription = new TransSubscription();
subscription.ConnectionContext = conn;
subscription.SubscriberName = subscriberName;
subscription.PublicationName = publicationName;
subscription.DatabaseName = publicationDbName;
subscription.SubscriptionDBName = subscriptionDbName;
// Specify the Windows login credentials for the Distribution Agent job.
subscription.SynchronizationAgentProcessSecurity.Login = winLogin;
subscription.SynchronizationAgentProcessSecurity.Password = winPassword;
// By default, subscriptions to transactional publications are synchronized
// continuously, but in this case we only want to synchronize on demand.
subscription.AgentSchedule.FrequencyType = ScheduleFrequencyType.OnDemand;
// Create the push subscription.
subscription.Create();
}
else
{
// Do something here if the publication does not exist.
throw new ApplicationException(String.Format(
"The publication '{0}' does not exist on {1}.",
publicationName, publisherName));
}
}
catch (Exception ex)
{
// Implement the appropriate error handling here.
throw new ApplicationException(String.Format(
"The subscription to {0} could not be created.", publicationName), ex);
}
finally
{
conn.Disconnect();
}
' Define the Publisher, publication, and databases.
Dim publicationName As String = "AdvWorksProductTran"
Dim publisherName As String = publisherInstance
Dim subscriberName As String = subscriberInstance
Dim subscriptionDbName As String = "AdventureWorks2012Replica"
Dim publicationDbName As String = "AdventureWorks2012"
'Create a connection to the Publisher.
Dim conn As ServerConnection = New ServerConnection(publisherName)
' Create the objects that we need.
Dim publication As TransPublication
Dim subscription As TransSubscription
Try
' Connect to the Publisher.
conn.Connect()
' Ensure that the publication exists and that
' it supports push subscriptions.
publication = New TransPublication()
publication.Name = publicationName
publication.DatabaseName = publicationDbName
publication.ConnectionContext = conn
If publication.IsExistingObject Then
If (publication.Attributes And PublicationAttributes.AllowPush) = 0 Then
publication.Attributes = publication.Attributes _
Or PublicationAttributes.AllowPush
End If
' Define the push subscription.
subscription = New TransSubscription()
subscription.ConnectionContext = conn
subscription.SubscriberName = subscriberName
subscription.PublicationName = publicationName
subscription.DatabaseName = publicationDbName
subscription.SubscriptionDBName = subscriptionDbName
' Specify the Windows login credentials for the Distribution Agent job.
subscription.SynchronizationAgentProcessSecurity.Login = winLogin
subscription.SynchronizationAgentProcessSecurity.Password = winPassword
' By default, subscriptions to transactional publications are synchronized
' continuously, but in this case we only want to synchronize on demand.
subscription.AgentSchedule.FrequencyType = ScheduleFrequencyType.OnDemand
' Create the push subscription.
subscription.Create()
Else
' Do something here if the publication does not exist.
Throw New ApplicationException(String.Format( _
"The publication '{0}' does not exist on {1}.", _
publicationName, publisherName))
End If
Catch ex As Exception
' Implement the appropriate error handling here.
Throw New ApplicationException(String.Format( _
"The subscription to {0} could not be created.", publicationName), ex)
Finally
conn.Disconnect()
End Try
Comentários
Ao configurar um Publicador com um Distribuidor remoto, os valores fornecidos para todos os parâmetros, incluindo SynchronizationAgentProcessSecurity, são enviados ao Distribuidor como texto sem formatação. É necessário criptografar a conexão entre o Publicador e o respectivo Distribuidor remoto antes de chamar o método Create. Para obter mais informações, consulte sp_reinitsubscription (Transact-SQL).
Quando a assinatura pertence a um Publicador não SQL Server, a ConnectionContext propriedade é definida como Distribuidor em vez de Publisher, a DatabaseName propriedade é definida como o banco de dados de distribuição em vez do banco de dados de publicação e a PublisherName propriedade é definida como o nome do Publicador não SQL Server.
Acesso thread-safe
Todos os membros estáticos públicos (Shared
no Microsoft Visual Basic) desse tipo são seguros para operações multithread. Não há garantia de que qualquer membro de instância seja seguro para threads.
Construtores
TransSubscription() |
Cria uma nova instância da classe TransSubscription. |
TransSubscription(String, String, String, String, ServerConnection) |
Cria uma nova instância da classe com a publicação, o banco de dados, o Assinante e o banco de TransSubscription dados do assinante especificados e com a conexão especificada com a instância do Microsoft SQL Server. |
Propriedades
AgentJobId |
Obtém a ID do trabalho de agente usado para sincronizar a assinatura. (Herdado de Subscription) |
AgentOffload |
Obtém ou define se o agente de sincronização é executado em um computador diferente do computador em que o trabalho do agente foi criado. Essa propriedade não tem mais suporte para Distribuidores que executam o Microsoft SQL Server 2005 e posterior. (Herdado de Subscription) |
AgentOffloadServer |
Obtém ou define o nome do computador remoto no qual o agente é executado ao usar a ativação de agente remota. (Herdado de Subscription) |
AgentSchedule |
Obtém a agenda do trabalho de agente a ser usada para sincronizar a assinatura. (Herdado de Subscription) |
BackupInformation |
Obtém ou define as informações necessárias para inicializar uma assinatura a partir de um backup. |
CachePropertyChanges |
Obtém ou define se as alterações feitas às propriedades de replicação devem ser armazenadas em cache ou aplicadas imediatamente. (Herdado de ReplicationObject) |
ConnectionContext |
Obtém ou define a conexão com uma instância do Microsoft SQL Server. (Herdado de ReplicationObject) |
CreateSyncAgentByDefault |
Obtém ou define se o trabalho de agente usado para sincronizar a assinatura é criado por padrão. (Herdado de Subscription) |
DatabaseName |
Obtém ou define o nome do banco de dados de publicação. (Herdado de Subscription) |
DtsPackageLocation |
Obtém ou define o local do pacote DTS (Serviços de Transformação de Dados) do Microsoft SQL Server 2000. |
DtsPackageName |
Obtém ou define o nome do pacote DTS (Serviços de Transformação de Dados) do Microsoft SQL Server 2000 que é aplicado no Assinante. |
DtsPackagePassword |
Define a senha usada para executar o pacote DTS (Serviços de Transformação de Dados) do Microsoft SQL Server 2000. |
EnabledForSynchronizationManager |
Especifica se a assinatura pode ser sincronizada usando o Microsoft Windows Synchronization Manager. (Herdado de Subscription) |
FullSubscription |
Obtém um valor que indica se a assinatura está completa. |
IsExistingObject |
Especifica se o objeto existe no servidor ou não. (Herdado de ReplicationObject) |
LoopBackDetection |
Obtém ou define se o Distribution Agent envia transações originadas no Assinante de volta para o Assinante. |
MemoryOptimized |
Representa uma assinatura push de uma publicação transacional ou de instantâneo. |
Name |
Obtém o nome atribuído a uma assinatura existente. (Herdado de Subscription) |
PublicationName |
Obtém ou define o nome da publicação à qual a assinatura assina. (Herdado de Subscription) |
PublisherName |
Obtém ou define o nome do Publicador quando a assinatura pertence a um Publicador não SQL Server. |
SecureDtsPackagePassword |
Define a senha (como um SecureString objeto) usada para executar o pacote DTS (Serviços de Transformação de Dados) do Microsoft SQL Server 2000. |
SqlServerName |
Obtém o nome da instância do Microsoft SQL Server à qual esse objeto está conectado. (Herdado de ReplicationObject) |
Status |
Obtém o status da assinatura. (Herdado de Subscription) |
SubscriberCatalog |
Obtém ou define o catálogo usado ao fazer uma conexão com o provedor OLE DB para um Assinante não SQL Server. |
SubscriberDatasource |
Nome da fonte de dados, conforme entendido pelo provedor OLE DB para um Assinante não SQL Server. |
SubscriberDatasourceType |
Identifica o tipo de fonte de dados que é um Assinante não SQL Server. |
SubscriberLocation |
Local do banco de dados conforme compreendido pelo provedor OLE DB para o Assinante não SQL Server. |
SubscriberName |
Obtém ou define o nome da instância do Microsoft SQL Server que corresponde ao Assinante. (Herdado de Subscription) |
SubscriberProvider |
PROGID (identificador programático exclusivo) com o qual o provedor OLE DB para o Assinante não SQL Server está registrado |
SubscriberProviderString |
A cadeia de conexão específica do provedor OLE DB é usada para se conectar à fonte de dados para assinantes não SQL Server. |
SubscriberSecurity |
Obtém o contexto de segurança usado para conexão ao Assinante. (Herdado de Subscription) |
SubscriberType |
Obtém ou define o comportamento da atualização de alterações de dados no Assinante. |
SubscriptionDBName |
Obtém ou define o nome do banco de dados no Assinante que recebe os dados replicados. (Herdado de Subscription) |
SubscriptionLSN |
Obtém ou define o número da sequência de log da assinatura. |
SubscriptionType |
Determina se o registro de assinatura é push ou pull. (Herdado de Subscription) |
SynchronizationAgent |
Obtém uma instância da classe TransSynchronizationAgent que pode ser usada para sincronizar a assinatura. |
SynchronizationAgentName |
Obtém ou define o nome do trabalho de agente criado para sincronizar a assinatura. (Herdado de Subscription) |
SynchronizationAgentProcessSecurity |
Obtém o contexto de segurança usado para especificar a conta do Microsoft Windows na qual o trabalho do agente de sincronização é executado para sincronizar a assinatura. (Herdado de Subscription) |
SyncType |
Obtém ou define a maneira na qual a assinatura é inicializada. (Herdado de Subscription) |
UserData |
Obtém ou define uma propriedade de objeto que permite que os usuários anexem seus próprios dados ao objeto. (Herdado de ReplicationObject) |
Métodos
CheckValidCreation() |
Verifica a criação de replicação válida. (Herdado de ReplicationObject) |
CheckValidDefinition(Boolean) |
Indica se definição da assinatura é válida. (Herdado de Subscription) |
CommitPropertyChanges() |
Envia todas as instruções de alteração de propriedade armazenadas em cache para a instância do Microsoft SQL Server. (Herdado de ReplicationObject) |
Create() |
Cria o registro de assinatura no Publicador. (Herdado de Subscription) |
Decouple() |
Desacopla o objeto de replicação referenciado do servidor. (Herdado de ReplicationObject) |
DoUpdateMemoryOptimizedProperty(String) |
Representa uma assinatura push de uma publicação transacional ou de instantâneo. |
GetChangeCommand(StringBuilder, String, String) |
Retorna o comando change da replicação. (Herdado de ReplicationObject) |
GetCreateCommand(StringBuilder, Boolean, ScriptOptions) |
Retorna o comando create da replicação. (Herdado de ReplicationObject) |
GetDropCommand(StringBuilder, Boolean) |
Retorna o comando drop da replicação. (Herdado de ReplicationObject) |
InternalRefresh(Boolean) |
Inicia uma atualização interna da replicação. (Herdado de ReplicationObject) |
Load() |
Carrega as propriedades de um objeto existente do servidor. (Herdado de ReplicationObject) |
LoadProperties() |
Carrega as propriedades de um objeto existente do servidor. (Herdado de ReplicationObject) |
Refresh() |
Recarrega as propriedades do objeto. (Herdado de ReplicationObject) |
Reinitialize() |
Marca a assinatura para reinicialização na próxima vez que o Agente de Distribuição for executado para sincronizar a assinatura. |
Reinitialize(Boolean) |
Reinicializa a assinatura. |
Remove() |
Exclui o registro de assinatura no Publicador e remove os objetos de replicação no Assinante para uma assinatura push. (Herdado de Subscription) |
Script(ScriptOptions) |
Retorna um script Transact-SQL que pode ser usado para criar ou excluir a assinatura. (Herdado de Subscription) |
StopSynchronizationJob() |
Tenta interromper um trabalho do Agente de Distribuição em execução que está sincronizando a assinatura atualmente. |
SynchronizeWithJob() |
Inicia o trabalho de agente para sincronizar a assinatura. |