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


Как повторно инициализировать подписку в SQL Server Compact Edition (программным путем)

В этом разделе объясняется, как заново инициализировать подписку в Microsoft SQL Server 2005 Compact Edition (SQL Server Compact Edition) с помощью класса SqlCeReplication. Дополнительные сведения об использовании пространства имен SqlServerCe см. в справочной документации по пространству имен SqlServerCe.

Повторная инициализация подписки

  1. Инициализируйте объект SqlCeReplication.

    SqlCeReplication repl = new SqlCeReplication();
    
  2. Настройте свойства соединения. В этих свойствах указывается имя и расположение публикации, на которую создается подписка, имя и расположение локальной базы данных SQL Server Compact Edition и расположение агента сервера SQL Server Compact Edition.

    repl.InternetUrl = "https://www.adventure-works.com/sqlmobile/sqlcesa30.dll";
    repl.InternetLogin = "MyInternetLogin";
    repl.InternetPassword = "<password>";
    repl.Publisher = "MyPublisher";
    repl.PublisherDatabase = "MyPublisherDatabase";
    repl.PublisherLogin = "MyPublisherLogin";
    repl.PublisherPassword = "<password>";
    repl.Publication = "MyPublication";
    repl.Subscriber = "MySubscriber";
    repl.SubscriberConnectionString = "Data Source=MyDatabase.sdf";
    
  3. Вызовите метод ReinitializeSubscription, чтобы пометить подписку для повторной инициализации. Если передать значение true в метод ReinitializeSubscription, изменения в подписчике будут загружены в издатель до выполнения повторной инициализации. Если передать значение false, все изменения в подписчике будут отменены при повторной инициализации.

    repl.ReinitializeSubscription(true);
    
  4. Чтобы заново наполнить подписку, следует вызвать метод Synchronize после вызова метода ReinitializeSubscription.

    repl.Synchronize();
    

Пример

В приведенном примере показано, как заново инициализировать подписку SQL Server Compact Edition. В этом примере сначала все изменения в подписчике загружаются в издатель, затем подписка заново инициализируется, после чего выполняется синхронизация данных.

SqlCeReplication repl = null;

try
{
   // Create SqlCeReplication instance
   //
   repl = new SqlCeReplication();
   repl.InternetUrl = "https://www.adventure-works.com/sqlmobile/sqlcesa30.dll";
   repl.InternetLogin = "MyInternetLogin";
   repl.InternetPassword = "<password>";
   repl.Publisher = "MyPublisher";
   repl.PublisherDatabase = "MyPublisherDatabase";
   repl.PublisherLogin = "MyPublisherLogin";
   repl.PublisherPassword = "<password>";
   repl.Publication = "MyPublication";
   repl.Subscriber = "MySubscriber";
   repl.SubscriberConnectionString = "Data Source=MyDatabase.sdf";

   // Mark the subscription for reinitialization with Upload first
  
   repl.ReinitializeSubscription(true);

   // Synchronize to SQL Server to populate the Subscription 

   repl.Synchronize();
}
catch (SqlCeException)
{
   // Handle errors here
}
finally
{
   // Dispose the repl object
   
   repl.Dispose();
}
Dim repl As SqlCeReplication = Nothing

Try
   ' Create SqlCeReplication instance

   repl = New SqlCeReplication()
   repl.InternetUrl = "https://www.adventure-works.com/sqlmobile/sqlcesa30.dll"
   repl.InternetLogin = "MyInternetLogin"
   repl.InternetPassword = "<password>"
   repl.Publisher = "MyPublisher"
   repl.PublisherDatabase = "MyPublisherDatabase"
   repl.PublisherLogin = "MyPublisherLogin"
   repl.PublisherPassword = "<password>"
   repl.Publication = "MyPublication"
   repl.Subscriber = "MySubscriber"
   repl.SubscriberConnectionString = "Data Source=MyDatabase.sdf"

   ' Mark the subscription for reinitialization with Upload first
            
   repl.ReinitializeSubscription(True)

   ' Synchronize to SQL Server to populate the Subscription 

   repl.Synchronize()
Catch
   ' Handle errors here
Finally
   ' Dispose the repl object
   
   repl.Dispose()
End Try

См. также

Основные понятия

Использование репликации слиянием
Подписка на публикации (SQL Server Compact Edition)
Повторная инициализация подписки (SQL Server Compact Edition)

Справка и поддержка

Получение помощи по SQL Server Compact Edition