Freigeben über


Verwenden von auf Zeilenversionsverwaltung basierenden Isolationsstufen

Das Framework für die Zeilenversionsverwaltung ist in Microsoft SQL Server 2005 immer aktiviert und wird von mehreren Features verwendet. Es stellt nicht nur auf Zeilenversionsverwaltung basierende Isolationsstufen bereit, sondern wird auch zur Unterstützung von Änderungen verwendet, die an Triggern und MARS-Sitzungen (Multiple Active Result Sets) vorgenommen werden; außerdem dient es zur Unterstützung von Datenlesevorgängen für ONLINE-Indexvorgänge.

Auf der Zeilenversionsverwaltung basierende Isolationsstufen werden auf der Datenbankebene aktiviert. Alle Anwendungen, die auf Objekte aus aktivierten Datenbanken zugreifen, können mithilfe der folgenden Isolationsstufen Abfragen ausführen:

  • READ COMMITTED (Commit vor dem Lesevorgang) mit Zeilenversionsverwaltung, indem die READ_COMMITTED_SNAPSHOT-Datenbankoption auf ON (wie im folgenden Codebeispiel gezeigt) festgelegt wird:

    ALTER DATABASE AdventureWorks
        SET READ_COMMITTED_SNAPSHOT ON;
    

    Wenn die Datenbank für READ_COMMITTED_SNAPSHOT aktiviert ist, verwenden alle Abfragen, die unter der Isolationsstufe READ COMMITTED ausgeführt werden, Zeilenversionsverwaltung. Dies bedeutet, dass die Lesevorgänge die Aktualisierungsvorgänge nicht blockieren.

  • Die Snapshotisolation durch Festlegen der Datenbankoption ALLOW_SNAPSHOT_ISOLATION auf ON, wie im folgenden Codebeispiel gezeigt:

    ALTER DATABASE AdventureWorks
        SET ALLOW_SNAPSHOT_ISOLATION ON;
    

    Eine Transaktion, die unter Snapshotisolation ausgeführt wird, kann auf Tabellen in der Datenbank zugreifen, die für die Snapshotfunktion aktiviert wurden. Wenn auf Tabellen zugegriffen werden soll, die nicht für Snapshot aktiviert wurden, muss die Isolationsstufe geändert werden. Das folgende Codebeispiel zeigt z. B. eine SELECT-Anweisung, die während der Ausführung unter einer Snapshottransaktion zwei Tabellen verknüpft. Eine der Tabellen gehört zu einer Datenbank, in der Snapshotisolation nicht aktiviert ist. Wenn die SELECT-Anweisung unter Snapshotisolation ausgeführt wird, ist die Ausführung nicht erfolgreich.

    SET TRANSACTION ISOLATION LEVEL SNAPSHOT;
    BEGIN TRAN
        SELECT t1.col5, t2.col5
            FROM Table1 as t1
            INNER JOIN SecondDB.dbo.Table2 as t2
                ON t1.col1 = t2.col2;
    

    Das folgende Codebeispiel zeigt die gleiche SELECT-Anweisung, die so bearbeitet wurde, dass die Transaktionsisolationsstufe in READ COMMITTED geändert wurde. Durch diese Änderung wird die SELECT-Anweisung erfolgreich ausgeführt.

    SET TRANSACTION ISOLATION LEVEL SNAPSHOT;
    BEGIN TRAN
        SELECT t1.col5, t2.col5
            FROM Table1 as t1
            WITH (READCOMMITTED)
            INNER JOIN SecondDB.dbo.Table2 as t2
                ON t1.col1 = t2.col2;
    

Weitere Informationen zum Festlegen der Isolationsstufe in einer Anwendung finden Sie unter Anpassen der Isolationsstufen von Transaktionen.

Einschränkungen von Transaktionen, die auf Zeilenversionsverwaltung basierende Isolationsstufen verwenden

Berücksichtigen Sie die folgenden Einschränkungen, wenn Sie mit auf Zeilenversionsverwaltung basierenden Isolationsstufen arbeiten:

  • READ_COMMITTED_SNAPSHOT kann in tempdb, msdb oder master nicht aktiviert werden.

  • Globale temporäre Tabellen werden in tempdb gespeichert. Wenn auf globale temporäre Tabellen in einer Snapshottransaktion zugegriffen wird, muss einer der folgenden Vorgänge erfolgen:

    • Festlegen der ALLOW_SNAPSHOT_ISOLATION-Datenbankoption auf ON in tempdb.
    • Verwenden eines Isolationshinweises zum Ändern der Isolationsstufe für die Anweisung.
  • Snapshottransaktionen erzeugen einen Fehler, wenn Folgendes zutrifft:

    • Eine Datenbank erhält nach dem Start der Snapshottransaktion, jedoch vor dem Zugriff auf die Datenbank durch die Snapshottransaktion einen Schreibschutz.
    • Beim Zugriff auf Objekte aus mehreren Datenbanken wurde ein Datenbankstatus so geändert, dass die Datenbankwiederherstellung nach dem Start einer Snapshottransaktion aufgetreten ist, jedoch vor dem Zugriff auf die Datenbank durch die Snapshottransaktion. Beispiel: Die Datenbank wurde auf OFFLINE und dann auf ONLINE festgelegt, auf automatisches Schließen und Öffnen oder auf Trennen und Anfügen.
  • Verteilte Transaktionen, z. B. Abfragen in verteilten partitionierten Datenbanken, werden unter Snapshotisolation nicht unterstützt.

  • SQL Server speichert nicht mehrere Versionen von Systemmetadaten. DDL-Anweisungen (Data Definition Language) für Tabellen und andere Datenbankobjekte (Indizes, Sichten, Datentypen, gespeicherte Prozeduren und CLR-Funktionen) verändern Metadaten. Wenn eine DDL-Anweisung ein Objekt ändert, bewirkt jeder gleichzeitige Verweis auf das Objekt unter Snapshotisolation, dass die Snapshottransaktion einen Fehler erzeugt. Für READ COMMITTED-Transaktionen gilt diese Einschränkung nicht, wenn die READ_COMMITTED_SNAPSHOT-Datenbankoption auf ON festgelegt wurde.
    Ein Datenbankadministrator führt z. B. die folgende ALTER INDEX-Anweisung aus.

    USE AdventureWorks;
    GO
    ALTER INDEX AK_Employee_LoginID
        ON HumanResources.Employee REBUILD;
    GO
    

    Für alle Snapshottransaktionen, die während der Ausführung der ALTER INDEX-Anweisung aktiviert sind, wird ein Fehler ausgegeben, wenn versucht wird, auf die HumanResources.Employee-Tabelle zu verweisen, nachdem die ALTER INDEX-Anweisung ausgeführt wurde. READ COMMITTED-Transaktionen, die Zeilenversionsverwaltung verwenden, sind nicht betroffen.

    ms179599.note(de-de,SQL.90).gifHinweis:
    BULK INSERT-Operationen können Änderungen an den Metadaten der Zieltabelle verursachen (z. B. beim Deaktivieren von Einschränkungsprüfungen). Sollte dies der Fall sein, schlagen gleichzeitige Snapshotisolationstransaktionen fehl, die auf Tabellen mit BULK INSERT zugreifen.

Siehe auch

Konzepte

Isolationsstufen im Datenbankmodul
Grundlegendes zu zeilenversionsbasierten Isolationsstufen
Auswählen von auf Zeilenversionsverwaltung basierenden Isolationsstufen
Aktivieren von zeilenversionsbasierten Isolationsstufen
Ressourcenverwendung bei der Zeilenversionsverwaltung

Andere Ressourcen

ALTER DATABASE (Transact-SQL)
SET TRANSACTION ISOLATION LEVEL (Transact-SQL)

Hilfe und Informationen

Informationsquellen für SQL Server 2005