MSSQL_ENG002601
Details zur Fehlermeldung
Produktname |
SQL Server |
Produktversion |
9.0 |
Buildnummer des Produkts |
9.00.1399.60 |
Ereignis-ID |
2601 |
Ereignisquelle |
MSSQLSERVER |
Komponente |
SQL Server-Datenbankmodul |
Symbolischer Name |
N/V |
Meldungstext |
Eine Zeile mit doppeltem Schlüssel kann in das %1!s!-Objekt mit dem eindeutigen %2!s!-Index nicht eingefügt werden. |
Erklärung
Dies ist ein allgemeiner Fehler, der unabhängig davon ausgelöst werden kann, ob eine Datenbank repliziert wird. Bei replizierten Datenbanken wird der Fehler in der Regel ausgelöst, weil Primärschlüssel in der Topologie nicht richtig verwaltet wurden. In einer verteilten Umgebung muss unbedingt sichergestellt werden, dass in mehreren Knoten nicht der gleiche Wert in eine Primärschlüsselspalte oder eine andere eindeutige Spalte eingefügt wird. Die folgenden Ursachen können zugrunde liegen:
- Einfügungen und Aktualisierungen an einer Zeile finden in mehreren Knoten statt. Die Mergereplikation und aktualisierbare Abonnements für Transaktionsreplikationen stellen jeweils eine Konflikterkennung und -lösung bereit. Dennoch ist es besser, eine bestimmte Zeile nur in einem Knoten einzufügen oder zu aktualisieren. Die Peer-to-Peer-Transaktionsreplikation stellt keine Konflikterkennung und -lösung bereit. Einfügungen und Aktualisierungen müssen partitioniert werden.
- Auf einem Abonnenten wurde eine Zeile eingefügt, die schreibgeschützt sein sollte. Abonnenten von Snapshotpublikationen sollten als schreibgeschützt behandelt werden, ebenso wie Abonnenten von Transaktionspublikationen, außer es werden aktualisierbare Abonnements oder die Peer-to-Peer-Transaktionsreplikation verwendet.
- Es wird eine Tabelle mit einer Identitätsspalte verwendet, die Spalte wird jedoch nicht ordnungsgemäß verwaltet.
- Bei der Mergereplikation kann dieser Fehler auch während eines INSERTs in die MSmerge_contents-Systemtabelle ausgelöst werden; die Fehlermeldung lautet dann ungefähr folgendermaßen: Eine Zeile mit doppeltem Schlüssel kann in das 'MSmerge_contents'-Objekt mit dem eindeutigen 'ucl1SycContents'-Index nicht eingefügt werden.
Benutzeraktion
Die erforderliche Aktion hängt davon ab, weshalb der Fehler ausgelöst wurde:
- Einfügungen und Aktualisierungen an einer Zeile finden in mehreren Knoten statt.
Unabhängig vom Typ der verwendeten Replikation wird empfohlen, Einfügungen und Aktualisierungen möglichst zu partitionieren, da dies den Verarbeitungsaufwand bei der Konflikterkennung und -lösung reduziert. Bei der Peer-to-Peer-Transaktionsreplikation ist eine Partitionierung von Einfügungen und Aktualisierungen erforderlich. Weitere Informationen finden Sie unter Peer-to-Peer-Transaktionsreplikation. - Auf einem Abonnenten wurde eine Zeile eingefügt, die schreibgeschützt sein sollte.
Fügen Sie auf dem Abonnenten keine Zeilen ein und aktualisieren Sie keine Zeilen, es sei denn Sie verwenden die Mergereplikation, die Transaktionsreplikation mit aktualisierbaren Abonnements oder die Peer-to-Peer-Transaktionsreplikation. - Es wird eine Tabelle mit einer Identitätsspalte verwendet, die Spalte wird jedoch nicht ordnungsgemäß verwaltet.
Bei der Mergereplikation und der Transaktionsreplikation mit aktualisierbaren Abonnements sollten Identitätsspalten automatisch durch die Replikation verwaltet werden. Bei der Peer-to-Peer-Transaktionsreplikation müssen sie manuell verwaltet werden. Weitere Informationen finden Sie unter Replizieren von Identitätsspalten. - Der Fehler tritt während eines INSERTs in der MSmerge_contents-Systemtabelle auf.
Dieser Fehler kann auftreten, wenn für die Verknüpfungsfiltereigenschaft join_unique_key ein falscher Wert festgelegt wurde. Diese Eigenschaft sollte nur auf TRUE festgelegt werden, wenn die verknüpfte Spalte in der übergeordneten Tabelle eindeutig ist. Wenn die Eigenschaft auf TRUE festgelegt ist, die Spalte jedoch nicht eindeutig ist, wird dieser Fehler ausgelöst. Weitere Informationen zum Festlegen dieser Eigenschaft finden Sie unter Vorgehensweise: Definieren und Ändern eines Verknüpfungsfilters zwischen Mergeartikeln (SQL Server Management Studio) und How to: Define and Modify a Join Filter Between Merge Articles (Replication Transact-SQL Programming).
Siehe auch
Konzepte
Ursachen und Lösungen für Replikationsfehler