Passo a passo: executando a sincronização com o segundo cliente
O segundo banco de dados compacto SyncCompactDB2 já deve estar em sincronização com o banco de dados servidor SyncDB porque o SyncCompactDB2 é um instantâneo do SyncCompactDB, que já estava sincronizado com o banco de dados SyncDB.
Neste passo a passo, você criará um aplicativo de console que sincroniza o segundo cliente compacto com o servidor, adiciona um novo registro ao servidor, sincroniza o segundo cliente compacto com o servidor e também sincroniza o primeiro cliente compacto com o servidor. Para obter mais detalhes técnicos sobre o provisionamento de servidores/clientes e a execução do processo de sincronização, consulte Como configurar e executar a sincronização de bancos de dados (SQL Server).
Para executar a sincronização
No Gerenciador de Soluções, clique com o botão direito do mouse em Solução ‘SyncSQLServerAndSQLCompact’, aponte para Adicionar e clique em Novo Projeto.
Selecione Visual C# em Tipos de Projeto e selecione Aplicativo do Console em Modelos.
Digite ExecuteSecondCompactSync para nome do projeto.
Clique em OK para fechar a caixa de diálogo Novo Projeto.
Na janela Gerenciador de Soluções, clique com o botão direito do mouse em ExecuteSecondCompactSync e clique em Adicionar Referência.
Selecione Microsoft.Synchronization, Microsoft.Synchornization.Data, Microsoft.Synchronization.Data.SqlServer, Microsoft.Synchronization.Data.SqlServerCe e clique em OK para fechar a caixa de diálogo Adicionar Referência.
Repita as duas etapas anteriores para adicionar uma referência ao assembly System.Data.SqlServerCe.
Adicione as instruções using a seguir ao início do arquivo Program.cs após as instruções using existentes.
using System.Data; using System.Data.SqlClient; using System.Data.SqlServerCe; using Microsoft.Synchronization; using Microsoft.Synchronization.Data; using Microsoft.Synchronization.Data.SqlServer; using Microsoft.Synchronization.Data.SqlServerCe;
Adicione a instrução a seguir ao método Main para criar uma conexão SQL com o segundo banco de dados compacto.
//create a connection to the second compact database SqlCeConnection clientConn = new SqlCeConnection(@"Data Source='C:\SyncSQLServerAndSQLCompact\SyncCompactDB2.sdf'");
Adicione a instrução a seguir ao método Main para criar uma conexão SQL com o banco de dados servidor.
//create connection to the server database SqlConnection serverConn = new SqlConnection("Data Source=localhost; Initial Catalog=SyncDB; Integrated Security=True");
Importante
Na instrução anterior, substitua o nome do servidor pelo nome da instância do seu servidor, caso não esteja usando a instância padrão. Por exemplo: se o nome de sua instância do SQL Server for MYSQLINSTANCE, substitua (local) por .\MYSQLINSTANCE.
Adicione o código a seguir ao método Main para criar um orquestrador de sincronização, que inicia e contra sessões de sincronização. O orquestrador de sincronização contém dois provedores de sincronização que participarão de uma sessão de sincronização. Em nosso cenário, você precisará usar um objeto de provedor para o banco de dados servidor e um objeto de provedor para o segundo banco de dados cliente compacto SQL Server. Etapas de alto nível para criar um orquestrador para este cenário:
Crie uma instância da classe SyncOrchestrator. A classe SyncOrchestrator inicia e controla sessões de sincronização.
Defina o provedor local do objeto do orquestrador de sincronização para um objeto SqlCeSyncProvider associado ao banco de dados cliente SyncCompactDB2. A classe SqlCeSyncProvider encapsula um provedor de sincronização para o SQL Server Compact que se comunica com o cliente e protege o orquestrador de sincronização contra a implementação específica do banco de dados cliente.
Defina o provedor remoto do orquestrador de sincronização para um objeto SqlSyncProvider associado ao banco de dados servidor SyncDB. A classe SqlSyncProvider representa um provedor de sincronização que se comunica com um banco de dados SQL Server e protege outros componentes do Sync Framework contra a implementação específica do banco de dados.
Defina a direção da sincronização do objeto do orquestrador de sincronização como UploadAndDownload para que o cliente possa baixar/carregar as alterações de/para o servidor.
// create a sync orchestrator SyncOrchestrator syncOrchestrator = new SyncOrchestrator(); // set the local provider to a CE sync provider associated with the // ProductsScope in the Sync Compact DB 2 database syncOrchestrator.LocalProvider = new SqlCeSyncProvider("ProductsScope", clientConn); // set the remote provider to a server sync provider associated with the // ProductsScope in the Sync DB server database syncOrchestrator.RemoteProvider = new SqlSyncProvider("ProductsScope", serverConn); // set the diretion to Upload and Download syncOrchestrator.Direction = SyncDirectionOrder.UploadAndDownload;
Adicione o código a seguir para assinar eventuais erros que ocorram durante a aplicação de alterações feitas no cliente. O evento ApplyChangeFailed será gerado quando uma linha não puder ser aplicada a um cliente. Você definirá o manipulador do evento de erro mais tarde neste passo a passo.
// subscribe for errors that occur when applying changes to the client ((SqlCeSyncProvider)syncOrchestrator.LocalProvider).ApplyChangeFailed += new EventHandler<DbApplyChangeFailedEventArgs>(Program_ApplyChangeFailed);
Adicione o código a seguir ao método Main para executar a sincronização entre o SQL Server e o SQL Server Compact. Esse código invoca o método Synchronize()()()() no objeto SyncOrchestrator para iniciar o processo de sincronização entre o banco de dados servidor SyncDB e o banco de dados compacto SyncCompactDB.
// execute the synchronization process SyncOperationStatistics syncStats = syncOrchestrator.Synchronize();
Adicione as instruções a seguir ao método Main para exibir as estatísticas retornadas pelo método Synchronize()()()(). O objeto SyncOperationStatistics retornado por esse método contém estatísticas sobre a sessão de sincronização que foi executada.
//print sync statistics Console.WriteLine("Start Time: " + syncStats.SyncStartTime); Console.WriteLine("Total Changes Uploaded: " + syncStats.UploadChangesTotal); Console.WriteLine("Total Changes Downloaded: " + syncStats.DownloadChangesTotal); Console.WriteLine("Complete Time: " + syncStats.SyncEndTime); Console.WriteLine(String.Empty);
Adicione o método do manipulador de eventos a seguir à classe Program depois do método Main para manipular o evento ApplyChangeFailed. O parâmetro DbApplyChangeFailedEventArgs fornece informações sobre o erro ou o conflito que provocou a falha. Em um manipulador do evento, você pode responder ao evento de várias maneiras, inclusive especificando se o provedor de sincronização deve tentar aplicar a linha novamente. A propriedade Error do objeto contém metadados sobre todas as exceções ocorridas durante a sincronização. O código de exemplo a seguir exibe esse erro e o tipo de conflito (do tipo DbConflictType) ocorrido durante a sincronização.
static void Program_ApplyChangeFailed(object sender, DbApplyChangeFailedEventArgs e) { // display conflict type Console.WriteLine(e.Conflict.Type); // display error message Console.WriteLine(e.Error); }
No Gerenciador de Soluções, clique com o botão direito do mouse em ExecuteSecondCompactSync e clique em Compilar.
No Gerenciador de Soluções, clique com o botão direito do mouse em ExecuteSecondCompactSync novamente e clique em Definir como Projeto de Inicialização.
Aviso
Se você não executar esta etapa e pressionar Ctrl+F5 novamente, o aplicativo ProvisionSecondCompactClient será reexecutado e você obterá uma mensagem de erro sobre o escopo que já existe no banco de dados cliente.
Pressione Ctrl+F5 para executar o programa. A saída deve ter esta aparência:
Start Time: 6/14/2010 8:03:31 PM Total Changes Uploaded: 0 Total Changes Downloaded: 0 Complete Time: 6/14/2010 8:03:34 PM Press any key to continue . . .
Note que nenhum registro foi baixado porque o cliente já está em sincronização com o servidor.
Pressione ENTER para fechar a janela do prompt de comando.
No SQL Server Management Studio, expanda (local) SQL Server, Bancos de Dados, SyncDB e Tabelas.
Clique com o botão direito do mouse em dbo.Products e clique em Editar 200 Linhas Superiores.
Adicione um registro no final com 5 como ID, Teclado Sem Fio para Nome e 30 para ListPrice. Verifique se o registro foi salvo pressionando TAB.
No Visual Studio, pressione Ctrl+F5 para reexecutar o programa cliente. A saída deve ter a aparência a seguir.
Start Time: 6/14/2010 8:06:21 PM Total Changes Uploaded: 0 Total Changes Downloaded: 1 Complete Time: 6/14/2010 8:06:23 PM Press any key to continue . . .
O registro adicionado ao servidor deve ser baixado no cliente agora. Você pode verificar isso usando as etapas a seguir.
No SQL Server Management Studio, selecione SQL Server Compact [My Computer\...\SyncCompactDB2].
Clique em Nova Consulta na barra de ferramentas.
Digite e execute (pressionando F5) o comando SQL a seguir para confirmar se os registros foram realmente baixados no cliente compacto.
select * from products
O primeiro cliente compacto ainda não está em sincronização. Para confirmar, faça o seguinte:
Na janela Pesquisador de Objetos, selecione SyncCompactDB (sem 2 no final).
Clique em Nova Consulta na barra de ferramentas.
Digite e execute o comando a seguir.
select * from products
O último registro adicionado ao servidor ainda não aparecerá. O segundo cliente está em sincronização, mas o primeiro cliente não.
No Visual Studio, em Gerenciador de Soluções, clique com o botão direito do mouse em ExecuteCompactSync e clique em Definir como Projeto de Inicialização.
No Visual Studio, pressione Ctrl+F5 para reexecutar o programa cliente. A saída deve ter a aparência a seguir.
Start Time: 6/14/2010 8:10:54 PM Total Changes Uploaded: 0 Total Changes Downloaded: 1 Complete Time: 6/14/2010 8:10:56 PM Press any key to continue . . .
O registro adicionado ao servidor deve ser baixado no primeiro cliente agora. Você pode verificar isso usando as seguintes etapas: No SQL Server Management Studio, execute o comando select executado antes no primeiro banco de dados compacto (SyncCompactDB).
Para familiarizar-se com a tecnologia Sync Framework, você pode adicionar/atualizar/excluir registros do servidor/cliente. Por exemplo, se você excluir um registro do servidor, o registro correspondente no banco de dados cliente deverá ser excluído na próxima sincronização do cliente com o servidor.
Mantenha o Visual Studio e o SQL Server Management Studio abertos se desejar executar o passo a passo opcional relacionado ao escopo parametrizado.
Exemplo de código completo
using System;
using System.Data;
using System.Data.SqlClient;
using System.Data.SqlServerCe;
using Microsoft.Synchronization;
using Microsoft.Synchronization.Data;
using Microsoft.Synchronization.Data.SqlServer;
using Microsoft.Synchronization.Data.SqlServerCe;
namespace ExecuteSecondCompactSync
{
class Program
{
static void Main(string[] args)
{
//create a connection to the second compact database
SqlCeConnection clientConn = new SqlCeConnection(@"Data Source='C:\SyncSQLServerAndSQLCompact\SyncCompactDB2.sdf'");
//create connection to the server database
SqlConnection serverConn = new SqlConnection("Data Source=localhost; Initial Catalog=SyncDB; Integrated Security=True");
// create a sync orchestrator
SyncOrchestrator syncOrchestrator = new SyncOrchestrator();
// set the local provider to a CE sync provider associated with the
// ProductsScope in the Sync Compact DB 2 database
syncOrchestrator.LocalProvider = new SqlCeSyncProvider("ProductsScope", clientConn);
// set the remote provider to a server sync provider associated with the
// ProductsScope in the Sync DB server database
syncOrchestrator.RemoteProvider = new SqlSyncProvider("ProductsScope", serverConn);
// set the diretion to Upload and Download
syncOrchestrator.Direction = SyncDirectionOrder.UploadAndDownload;
// subscribe for errors that occur when applying changes to the client
((SqlCeSyncProvider)syncOrchestrator.LocalProvider).ApplyChangeFailed += new EventHandler<DbApplyChangeFailedEventArgs>(Program_ApplyChangeFailed);
// execute the synchronization process
SyncOperationStatistics syncStats = syncOrchestrator.Synchronize();
}
static void Program_ApplyChangeFailed(object sender, DbApplyChangeFailedEventArgs e)
{
// display conflict type
Console.WriteLine(e.Conflict.Type);
// display error message
Console.WriteLine(e.Error);
}
}
}
Consulte também
Outros recursos
Como configurar e executar a sincronização de bancos de dados (SQL Server)