I passaggi seguenti spiegano come configurare un database SQL di Azure da utilizzare con Datastream.
Per configurare un database SQL di Azure:
Abilita Change Data Capture (CDC) per il tuo database SQL di Azure di origine. Per farlo, collegati al database utilizzando Azure Data Studio o SQL Server Management Studio ed esegui questo comando:
EXEC sys.sp_cdc_enable_db; GO
Abilita CDC nelle tabelle per le quali devi acquisire le modifiche:
EXEC sys.sp_cdc_enable_table @source_schema = N'SCHEMA_NAME', @source_name = N'TABLE_NAME', @role_name = NULL GO
Sostituisci quanto segue:
SCHEMA_NAME
: il nome dello schema a cui appartengono le tabelleTABLE_NAME
: il nome della tabella per cui vuoi abilitare CDC
Avvia l'agente SQL Server e assicurati che sia sempre in esecuzione. Se l'agente SQL Server rimane inattivo per un periodo prolungato, i log potrebbero essere troncati, con una perdita permanente dei dati delle modifiche non letti da Datastream.
Per informazioni sull'esecuzione dell'agente SQL Server, consulta Avviare, arrestare o riavviare un'istanza dell'agente SQL Server.
Attiva l'isolamento degli snapshot.
Quando esegui il backfill dei dati dal database SQL Server, è importante garantire snapshot coerenti. Se non applichi le impostazioni descritte in questa sezione, le modifiche apportate al database durante il processo di backfill potrebbero generare duplicati o risultati errati, in particolare per le tabelle senza chiavi primarie.
L'abilitazione dell'isolamento degli snapshot crea una visualizzazione temporanea del database all'inizio del processo di backfill. In questo modo, i dati copiati rimangono coerenti, anche se altri utenti stanno apportando modifiche alle tabelle attive contemporaneamente. L'attivazione dell'isolamento degli snapshot potrebbe avere un leggero impatto sulle prestazioni, ma è essenziale per un'estrazione di dati affidabile.
Per abilitare l'isolamento degli snapshot:
- Connettiti al tuo database utilizzando un client SQL Server.
- Esegui questo comando:
ALTER DATABASE DATABASE_NAME SET ALLOW_SNAPSHOT_ISOLATION ON;
Sostituisci DATABASE_NAME con il nome del tuo database.
Crea un utente Datastream:
Connettiti al database
master
e crea un accesso:USE master; CREATE LOGIN YOUR_LOGIN WITH PASSWORD = 'PASSWORD';
Connettiti al database di origine e crea un utente per il tuo accesso:
USE DATABASE_NAME CREATE USER USER_NAME FOR LOGIN YOUR_LOGIN;
Assegna i ruoli
db_owner
edb_denydatawriter
all'utente:EXEC sp_addrolemember 'db_owner', 'USER_NAME'; EXEC sp_addrolemember 'db_denydatawriter', 'USER_NAME';