Een transactioneel consistente kopie van een database kopiëren in Azure SQL Database

Van toepassing op: Azure SQL Database

Azure SQL Database biedt verschillende methoden voor het maken van een kopie van een bestaande database op dezelfde server of een andere server. U kunt een database kopiëren met behulp van Azure Portal, PowerShell, Azure CLI of Transact-SQL.

Notitie

Microsoft Entra-id is de nieuwe naam voor Azure Active Directory (Azure AD). Op dit moment wordt de documentatie bijgewerkt.

Overzicht

Een databasekopie is een transactioneel consistente momentopname van de brondatabase vanaf een bepaald tijdstip nadat de kopieeraanvraag is gestart. U kunt dezelfde server of een andere server voor de kopie selecteren. U kunt er ook voor kiezen om de back-upredundantie en rekenkracht van de brondatabase te behouden, of een andere redundantie en/of rekenkracht binnen dezelfde servicelaag te gebruiken. Nadat de kopie is voltooid, wordt het een volledig functionele, onafhankelijke database. De aanmeldingen, gebruikers en machtigingen in de gekopieerde database worden onafhankelijk van de brondatabase beheerd. De kopie wordt gemaakt met behulp van de geo-replicatietechnologie. Zodra de replica-seeding is voltooid, wordt de geo-replicatiekoppeling automatisch beëindigd. Alle vereisten voor het gebruik van geo-replicatie zijn van toepassing op de kopieerbewerking van de database. Zie overzicht van actieve geo-replicatie voor meer informatie.

Notitie

Azure Portal, PowerShell en de Azure CLI bieden geen ondersteuning voor het kopiëren van databases naar een ander abonnement.

Databasekopie voor Azure SQL Hyperscale

Voor Azure SQL Hyperscale bepaalt de doeldatabase of de kopie een snelle kopie is of een grootte van de gegevenskopie.

  • Snel kopiëren: wanneer de kopie wordt uitgevoerd in dezelfde regio als de bron, wordt de kopie gemaakt op basis van de momentopnamen van blobs, is deze kopie een snelle bewerking, ongeacht de grootte van de database.

  • Grootte van gegevens kopiëren: wanneer de doeldatabase zich in een andere regio bevindt dan de bron of als de redundantie van de databaseback-upopslag (lokaal, zonegebonden, geo) van het doel verschilt van de brondatabase, is de kopieerbewerking een grootte van de gegevensbewerking. De kopieertijd is niet rechtstreeks evenredig met de grootte, omdat paginaserver-blobs parallel worden gekopieerd.

Aanmeldingen in de databasekopie

Wanneer u een database naar dezelfde server kopieert, kunnen dezelfde aanmeldingen voor beide databases worden gebruikt. De beveiligingsprincipaal die u gebruikt om de database te kopiëren, wordt de eigenaar van de database in de nieuwe database.

Wanneer u een database naar een andere server kopieert, wordt de beveiligingsprincipal die de kopieerbewerking op de doelserver heeft geïnitieerd, de eigenaar van de nieuwe database.

Ongeacht de doelserver worden alle databasegebruikers, machtigingen en beveiligings-id's (SID's) gekopieerd naar de databasekopie. Als u ingesloten databasegebruikers gebruikt voor gegevenstoegang, zorgt u ervoor dat de gekopieerde database dezelfde gebruikersreferenties heeft, zodat nadat de kopie is voltooid, u er onmiddellijk toegang toe hebt met dezelfde referenties.

Als u aanmeldingen op serverniveau gebruikt voor gegevenstoegang en de database naar een andere server kopieert, werkt de op aanmelding gebaseerde toegang mogelijk niet. Dit kan gebeuren omdat de aanmeldingen niet bestaan op de doelserver of omdat deze wachtwoorden en beveiligings-id's (SID's) verschillend zijn. Zie Azure SQL Database-beveiliging beheren na noodherstel voor meer informatie over het beheren van aanmeldingen wanneer u een database naar een andere server kopieert. Nadat de kopieerbewerking naar een andere server is geslaagd en voordat andere gebruikers opnieuw worden toegewezen, kan alleen de aanmelding die is gekoppeld aan de database-eigenaar of de serverbeheerder zich aanmelden bij de gekopieerde database. Zie Aanmeldingen oplossen en gegevenstoegang tot stand brengen nadat de kopieerbewerking is voltooid.

Kopiëren met Azure Portal

Als u een database wilt kopiëren met behulp van Azure Portal, opent u de pagina voor uw database en kiest u Kopiëren om de pagina SQL Database maken - Database kopiëren te openen. Vul de waarden in voor de doelserver waarnaar u de database wilt kopiëren.

Screenshot of Azure portal, showing Database copy option highlighted on the database overview page.

Kopiëren met Behulp van PowerShell of de Azure CLI

Gebruik de volgende voorbeelden om een database te kopiëren.

Gebruik voor PowerShell de cmdlet New-AzSqlDatabaseCopy .

Belangrijk

De Module PowerShell Azure Resource Manager (RM) wordt nog steeds ondersteund door Azure SQL Database, maar alle toekomstige ontwikkeling is voor de Az.Sql-module. De AzureRM-module blijft tot ten minste december 2020 bugfixes ontvangen. De argumenten voor de opdrachten in de Az-module en in de AzureRm-modules zijn vrijwel identiek. Zie Introductie van de nieuwe Az-module van Azure PowerShell voor meer informatie over de compatibiliteit van de argumenten.

New-AzSqlDatabaseCopy -ResourceGroupName "<resourceGroup>" -ServerName $sourceserver -DatabaseName "<databaseName>" `
    -CopyResourceGroupName "myResourceGroup" -CopyServerName $targetserver -CopyDatabaseName "CopyOfMySampleDatabase"

De databasekopie is een asynchrone bewerking, maar de doeldatabase wordt onmiddellijk nadat de aanvraag is geaccepteerd gemaakt. Als u de kopieerbewerking wilt annuleren terwijl deze nog wordt uitgevoerd, verwijdert u de doeldatabase met behulp van de cmdlet Remove-AzSqlDatabase .

Zie Een database naar een nieuwe server kopiëren voor een volledig PowerShell-voorbeeldscript.

Kopiëren met Transact-SQL

Meld u aan bij de master database met de aanmeldgegevens van de serverbeheerder of de aanmelding waarmee u de database hebt gemaakt die u wilt kopiëren. Als het kopiëren van de database is voltooid, moeten aanmeldingen die niet de serverbeheerder zijn lid zijn van de dbmanager-rol . Zie Aanmeldingen beheren voor meer informatie over aanmeldingen en verbinding maken met de server.

Begin met het kopiëren van de brondatabase met de CREATE DATABASE ... AS COPY OF statement. De T-SQL-instructie wordt uitgevoerd totdat de databasekopiebewerking is voltooid.

Notitie

Als u de T-SQL-instructie beëindigt, wordt de kopieerbewerking van de database niet beëindigd. Als u de bewerking wilt beëindigen, moet u de doeldatabase verwijderen.

Kopiëren naar dezelfde server

Meld u aan bij de master database met de aanmeldgegevens van de serverbeheerder of de aanmelding waarmee u de database hebt gemaakt die u wilt kopiëren. Als het kopiëren van de database is voltooid, moeten aanmeldingen die niet de serverbeheerder zijn lid zijn van de dbmanager-rol .

Met deze opdracht wordt gekopieerd Database1 naar een nieuwe database met de naam Database2 op dezelfde server. Afhankelijk van de grootte van uw database, Azure SQL Database kan het kopiëren wel even duren.

-- Execute on the master database to start copying
CREATE DATABASE Database2 AS COPY OF Database1;

Kopiëren naar een elastische pool

Meld u aan bij de master database met de aanmeldgegevens van de serverbeheerder of de aanmelding waarmee u de database hebt gemaakt die u wilt kopiëren. Als het kopiëren van de database is voltooid, moeten aanmeldingen die niet de serverbeheerder zijn lid zijn van de dbmanager-rol .

Met deze opdracht wordt gekopieerd Database1 naar een nieuwe database met de naam Database2 in een elastische pool met de naam pool1. Afhankelijk van de grootte van uw database, Azure SQL Database kan het kopiëren wel even duren.

Database1 kan een individuele of pooldatabase zijn. Kopiëren tussen verschillende laagpools wordt ondersteund, maar sommige exemplaren in meerdere lagen mislukken. U kunt bijvoorbeeld een individuele of elastische standaarddatabase kopiëren naar een groep voor algemeen gebruik, maar u kunt geen standaard elastische database kopiëren naar een Premium-pool.

-- Execute on the master database to start copying
CREATE DATABASE Database2
AS COPY OF Database1
(SERVICE_OBJECTIVE = ELASTIC_POOL( name = pool1 ));

Kopiëren naar een andere server

Verbinding maken naar de master database van de doelserver waar de nieuwe database moet worden gemaakt. Gebruik een aanmelding met dezelfde naam en hetzelfde wachtwoord als de database-eigenaar van de brondatabase op de bronserver. De aanmelding op de doelserver moet ook lid zijn van de dbmanager-rol of de aanmeldgegevens van de serverbeheerder zijn.

Met deze opdracht wordt Database1 op server1 gekopieerd naar een nieuwe database met de naam Database2 server2. Afhankelijk van de grootte van uw database, Azure SQL Database kan het kopiëren wel even duren.

-- Execute on the master database of the target server (server2) to start copying from Server1 to Server2
CREATE DATABASE Database2 AS COPY OF server1.Database1;

Belangrijk

De firewalls van beide servers moeten worden geconfigureerd om binnenkomende verbinding vanaf het IP-adres van de client die de T-SQL CREATE DATABASE uitgeeft toe te staan... AS COPY OF command. Als u het bron-IP-adres van de huidige verbinding wilt bepalen, voert u SELECT client_net_address FROM sys.dm_exec_connections WHERE session_id = @@SPID;

Notitie

Databasekopie met T-SQL wordt niet ondersteund bij het maken van verbinding met de doelserver via een privé-eindpunt. Als een privé-eindpunt is geconfigureerd maar openbare netwerktoegang is toegestaan, wordt databasekopie ondersteund wanneer deze is verbonden met de doelserver vanaf een openbaar IP-adres met behulp van SQL-verificatie. Zodra de kopieerbewerking is voltooid, kan openbare toegang worden geweigerd.

Op dezelfde manier kopieert Database1 de onderstaande opdracht op server1 naar een nieuwe database met de naam Database2 pool2 in een elastische pool met de naam pool2 op server2.

-- Execute on the master database of the target server (server2) to start copying from Server1 to Server2
CREATE DATABASE Database2 AS COPY OF server1.Database1 (SERVICE_OBJECTIVE = ELASTIC_POOL( name = pool2 ) );

Kopiëren naar een ander abonnement

U kunt de stappen in de sectie Een SQL Database kopiëren naar een andere server gebruiken om uw database te kopiëren naar een server in een ander abonnement met behulp van T-SQL. Zorg ervoor dat u een aanmelding gebruikt met dezelfde naam en hetzelfde wachtwoord als de database-eigenaar van de brondatabase. Daarnaast moet de aanmelding lid zijn van de dbmanager-rol of een serverbeheerder op zowel bron- als doelservers.

Tip

Wanneer u databases kopieert in dezelfde Microsoft Entra ID-tenant, wordt autorisatie op de bron- en doelservers vereenvoudigd als u de kopieeropdracht start met behulp van een verificatieaanmelding met voldoende toegang op beide servers. Het minimale vereiste toegangsniveau is lidmaatschap van de dbmanager-rol in de master database op beide servers. U kunt bijvoorbeeld een Microsoft Entra ID-aanmelding gebruiken die lid is van een groep die is aangewezen als de serverbeheerder op beide servers.

--Step# 1
--Create login and user in the master database of the source server.

CREATE LOGIN loginname WITH PASSWORD = 'xxxxxxxxx'
GO
CREATE USER [loginname] FOR LOGIN [loginname] WITH DEFAULT_SCHEMA=[dbo];
GO
ALTER ROLE dbmanager ADD MEMBER loginname;
GO

--Step# 2
--Create the user in the source database and grant dbowner permission to the database.

CREATE USER [loginname] FOR LOGIN [loginname] WITH DEFAULT_SCHEMA=[dbo];
GO
ALTER ROLE db_owner ADD MEMBER loginname;
GO

--Step# 3
--Capture the SID of the user "loginname" from master database

SELECT [sid] FROM sysusers WHERE [name] = 'loginname';

--Step# 4
--Connect to Destination server.
--Create login and user in the master database, same as of the source server.

CREATE LOGIN loginname WITH PASSWORD = 'xxxxxxxxx', SID = [SID of loginname login on source server];
GO
CREATE USER [loginname] FOR LOGIN [loginname] WITH DEFAULT_SCHEMA=[dbo];
GO
ALTER ROLE dbmanager ADD MEMBER loginname;
GO

--Step# 5
--Execute the copy of database script from the destination server using the credentials created

CREATE DATABASE new_database_name
AS COPY OF source_server_name.source_database_name;

Tip

Databasekopie met behulp van T-SQL ondersteunt het kopiëren van een database vanuit een abonnement in een andere Azure-tenant. Dit wordt alleen ondersteund wanneer u een SQL-verificatieaanmelding gebruikt om u aan te melden bij de doelserver. Het maken van een databasekopie op een logische server in een andere Azure-tenant wordt niet ondersteund wanneer Microsoft Entra-verificatie actief is (ingeschakeld) op de logische bron- of doelserver.

De voortgang van de kopieerbewerking controleren

Bewaak het kopieerproces door query's uit te voeren op de sys.databases, sys.dm_database_copies en sys.dm_operation_status weergaven. Terwijl het kopiëren wordt uitgevoerd, wordt de state_desc kolom van de sys.databases weergave voor de nieuwe database ingesteld op COPYING.

  • Als het kopiëren mislukt, wordt de state_desc kolom van de sys.databases weergave voor de nieuwe database ingesteld op SUSPECT. Voer de DROP-instructie uit op de nieuwe database en probeer het later opnieuw.
  • Als het kopiëren slaagt, wordt de state_desc kolom van de sys.databases weergave voor de nieuwe database ingesteld op ONLINE. Het kopiëren is voltooid en de nieuwe database is een gewone database die onafhankelijk van de brondatabase kan worden gewijzigd.

Notitie

Als u besluit het kopiëren te annuleren terwijl het wordt uitgevoerd, voert u de INSTRUCTIE DROP DATABASE uit op de nieuwe database.

Belangrijk

Als u een kopie wilt maken met een aanzienlijk kleinere servicedoelstelling dan de bron, beschikt de doeldatabase mogelijk niet over voldoende resources om het seedingproces te voltooien en kan de kopieerbewerking mislukken. In dit scenario gebruikt u een aanvraag voor geo-herstel om een kopie te maken op een andere server en/of een andere regio. Zie Een Azure SQL Database herstellen met behulp van databaseback-ups voor meer informatie.

Azure RBAC-rollen en -machtigingen voor het beheren van databasekopie

Als u een databasekopie wilt maken, moet u de volgende rollen hebben:

  • Abonnementseigenaar of
  • Rol SQL Server-inzender of
  • Aangepaste rol op de bronserver met de volgende machtigingen:
    • Microsoft.Sql/servers/databases/read
    • Microsoft.Sql/servers/databases/schrijven en
  • Aangepaste rol op de doelserver met de volgende machtigingen:
    • Microsoft.Sql/servers/read
    • Microsoft.Sql/servers/databases/read
    • Microsoft.Sql/servers/databases/schrijven

Als u een databasekopie wilt annuleren, moet u de volgende rollen hebben:

  • Abonnementseigenaar of
  • Rol SQL Server-inzender of
  • Aangepaste rol in de doeldatabase met de volgende machtiging:
    • Microsoft.Sql/servers/databases/delete

Als u databasekopie wilt beheren met behulp van Azure Portal, hebt u ook de volgende machtigingen nodig:

  • Microsoft.Resources/subscriptions/resources/read
  • Microsoft.Resources/deployments/read
  • Microsoft.Resources/deployments/write
  • Microsoft.Resources/deployments/operationstatuses/read

Als u de bewerkingen onder implementaties in de resourcegroep in de portal wilt zien, hebt u deze aanvullende machtigingen nodig voor bewerkingen tussen meerdere resourceproviders, waaronder SQL-bewerkingen:

  • Microsoft.Resources/subscriptions/resourcegroups/deployments/operations/read
  • Microsoft.Resources/subscriptions/resourcegroups/deployments/operationstatuses/read

Aanmeldingen oplossen

Nadat de nieuwe database online is op de doelserver, gebruikt u de instructie ALTER USER om de gebruikers van de nieuwe database opnieuw toe te kennen aan aanmeldingen op de doelserver. Als u zwevende gebruikers wilt oplossen, raadpleegt u Problemen met zwevende gebruikers oplossen. Zie ook Hoe u azure SQL Database-beveiliging beheert na herstel na noodgevallen.

Alle gebruikers in de nieuwe database behouden de machtigingen die ze in de brondatabase hadden. De gebruiker die de databasekopie heeft gestart, wordt de eigenaar van de nieuwe database. Nadat het kopiëren is voltooid en voordat andere gebruikers opnieuw worden toegewezen, kan alleen de eigenaar van de database zich aanmelden bij de nieuwe database.

Zie Azure SQL Database-beveiliging beheren na noodherstel voor meer informatie over het beheren van gebruikers en aanmeldingen wanneer u een database naar een andere server kopieert.

Databasekopiefouten

De volgende fouten kunnen optreden tijdens het kopiëren van een database in Azure SQL Database. Zie Een Azure SQL Database kopiëren voor meer informatie.

Foutcode Ernst Beschrijving
40635 16 Client met IP-adres %.*ls is tijdelijk uitgeschakeld.
40637 16 Het maken van een databasekopie is momenteel uitgeschakeld.
40561 16 Het kopiëren van de database is mislukt. De bron- of doeldatabase bestaat niet.
40562 16 Het kopiëren van de database is mislukt. De brondatabase is verwijderd.
40563 16 Het kopiëren van de database is mislukt. De doeldatabase is verwijderd.
40564 16 Het kopiëren van de database is mislukt vanwege een interne fout. Verwijder de doeldatabase en probeer het opnieuw.
40565 16 Het kopiëren van de database is mislukt. Niet meer dan één gelijktijdige databasekopie uit dezelfde bron is toegestaan. Verwijder de doeldatabase en probeer het later opnieuw.
40566 16 Het kopiëren van de database is mislukt vanwege een interne fout. Verwijder de doeldatabase en probeer het opnieuw.
40567 16 Het kopiëren van de database is mislukt vanwege een interne fout. Verwijder de doeldatabase en probeer het opnieuw.
40568 16 Het kopiëren van de database is mislukt. De brondatabase is niet meer beschikbaar. Verwijder de doeldatabase en probeer het opnieuw.
40569 16 Het kopiëren van de database is mislukt. De doeldatabase is niet meer beschikbaar. Verwijder de doeldatabase en probeer het opnieuw.
40570 16 Het kopiëren van de database is mislukt vanwege een interne fout. Verwijder de doeldatabase en probeer het later opnieuw.
40571 16 Het kopiëren van de database is mislukt vanwege een interne fout. Verwijder de doeldatabase en probeer het later opnieuw.