Поделиться через


TransSubscription Конструкторы

Определение

Создает новый экземпляр класса TransSubscription.

Перегрузки

TransSubscription()

Создает новый экземпляр класса TransSubscription.

TransSubscription(String, String, String, String, ServerConnection)

Создает новый экземпляр класса с указанными TransSubscription базами данных публикации, базы данных, подписчика и базы данных подписчика, а также с указанным соединением с экземпляром Microsoft SQL Server.

Комментарии

Обновлен текст:17 июля 2006 г.

В следующей таблице показаны значения свойств по умолчанию для нового экземпляра TransSubscription. Все свойства, не перечисленные явным образом в этой таблице, инициализируются значением null .

Свойство Значение по умолчанию
AgentOffload false
AgentSchedule Значение 99991231 для ActiveEndDate

Значение 235959 для ActiveEndTime

Значение 0 для ActiveStartDate

Значение 0 для ActiveStartTime

Значение 1 для FrequencyInterval

Значение 0 для FrequencyRecurrenceFactor

Значение для FirstFrequencyRelativeInterval

Значение для MinuteFrequencySubDay

Значение 5 для FrequencySubDayInterval

Значение для ContinuouslyFrequencyType
CachePropertyChanges false
CreateSyncAgentByDefault true
EnabledForSynchronizationManager false
FullSubscription true
IsExistingObject false
LoopBackDetection true
Status Значение для InactiveSubscriptionState
SubscriberDatasourceType Значение для SqlServerSubscriberType
SubscriberSecurity Значение для trueWindowsAuthentication
SubscriberType Значение для ReadOnlyTransSubscriberType
SubscriptionType Значение для PushSubscriptionOption
SynchronizationAgent Экземпляр TransSynchronizationAgent из публикации, связанной с создаваемой подпиской.
SyncType Значение для AutomaticSubscriptionSyncType

TransSubscription()

Создает новый экземпляр класса TransSubscription.

public:
 TransSubscription();
public TransSubscription ();
Public Sub New ()

Примеры

           // 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

Комментарии

Используемый по умолчанию конструктор инициализирует все поля в значения, установленные для них по умолчанию.

См. также раздел

Применяется к

TransSubscription(String, String, String, String, ServerConnection)

Создает новый экземпляр класса с указанными TransSubscription базами данных публикации, базы данных, подписчика и базы данных подписчика, а также с указанным соединением с экземпляром Microsoft SQL Server.

public:
 TransSubscription(System::String ^ publicationName, System::String ^ databaseName, System::String ^ subscriberName, System::String ^ subscriptionDBName, Microsoft::SqlServer::Management::Common::ServerConnection ^ connectionContext);
public TransSubscription (string publicationName, string databaseName, string subscriberName, string subscriptionDBName, Microsoft.SqlServer.Management.Common.ServerConnection connectionContext);
new Microsoft.SqlServer.Replication.TransSubscription : string * string * string * string * Microsoft.SqlServer.Management.Common.ServerConnection -> Microsoft.SqlServer.Replication.TransSubscription
Public Sub New (publicationName As String, databaseName As String, subscriberName As String, subscriptionDBName As String, connectionContext As ServerConnection)

Параметры

publicationName
String

Значение типа String, указывающее имя публикации транзакций или моментальных снимков.

databaseName
String

Значение String типа , указывающее имя базы данных, содержащей публикацию, или имя базы данных распространителя для издателя, не являющегося SQL Server.

subscriberName
String

Значение типа String, указывающее имя подписчика.

subscriptionDBName
String

Значение типа String, указывающее имя базы данных подписки.

connectionContext
ServerConnection

Объект ServerConnection , представляющий соединение с издателем или распространителем для подписки на издатель, не SQL Server.

Применяется к