I passaggi seguenti illustrano come configurare un database Azure SQL per l'utilizzo con Datastream.
Per configurare un database Azure SQL:
Attiva la funzionalità Change Data Capture (CDC) per il database Azure SQL di origine. Per farlo, connettiti al database utilizzando Azure Data Studio o SQL Server Management Studio ed esegui il seguente comando:
EXEC sys.sp_cdc_enable_db; GO
Abilita la CDC nelle tabelle di cui 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 attivare la copia dei dati dal canale dinamico
Attiva l'isolamento degli snapshot.
Quando esegui il backfill dei dati dal database SQL Server, è importante garantire screenshot coerenti. Se non applichi le impostazioni descritte in questa sezione, le modifiche apportate al database durante il processo di backfill potrebbero generare risultati duplicati o errati, in particolare per le tabelle senza chiavi primarie.
L'attivazione 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 apportano modifiche alle tabelle in tempo reale contemporaneamente. L'attivazione dell'isolamento degli snapshot potrebbe avere un lieve impatto sulle prestazioni, ma è obbligatoria per un'estrazione dei dati affidabile.
Per attivare l'isolamento degli snapshot:
- Connettiti al 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 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';
Passaggi successivi
- Scopri di più su come Datastream funziona con le origini SQL Server.