Automatische Inkrementierung von Daten mit ROW_NUMBER() ohne ORDER BY
Beim Einfügen von Daten in eine Tabelle ohne Identitätsspalte ist dies erforderlich Finden Sie alternative Methoden zur automatischen Inkrementierung des Primärschlüssels. Ein häufig verwendeter Ansatz ist die Funktion ROW_NUMBER(), die eine fortlaufende Nummerierung von Zeilen ermöglicht.
Traditionell erfordert die Funktion ROW_NUMBER() eine ORDER BY-Klausel, um die Reihenfolge der Zeilen zu bestimmen. Es gibt jedoch Szenarien, in denen kein legitimes Bestellfeld verfügbar ist. Um dieses Problem zu beheben, gibt es eine Problemumgehung, bei der ein beliebiger konstanter Ausdruck in der ORDER BY-Klausel verwendet wird, z. B. (SELECT 1).
Durch die Kombination dieser Technik mit der OVER()-Klausel wird es möglich, die zu berechnen Zeilennummer für jede Zeile, ohne eine bestimmte Reihenfolge anzugeben:
Row_Number() OVER (ORDER BY (SELECT 1))
Dieser Ausdruck kann dann in einer INSERT-Anweisung verwendet werden, um die primäre Zeile automatisch zu erhöhen key:
INSERT INTO dbo.TargetTable (ID, FIELD) SELECT Row_Number() OVER (ORDER BY (SELECT 1)) + Coalesce( (SELECT Max(ID) FROM dbo.TargetTable WITH (TABLOCKX, HOLDLOCK)), 0 ), FieldValue FROM dbo.SourceTable WHERE {somecondition};
Es ist jedoch wichtig zu beachten, dass diese Problemumgehung nicht die Beibehaltung der ursprünglichen Reihenfolge der Zeilen aus der SourceTable garantiert. Tatsächlich kann es andere Faktoren geben, die die endgültige Reihenfolge des Ergebnisses beeinflussen. Dies liegt daran, dass sich das Konzept „nicht (in einer bestimmten Weise) geordnet“ von „beibehalten der ursprünglichen Reihenfolge“ unterscheidet.
Daher gilt die Verwendung einer Identitätsspalte für die automatische Inkrementierung von Primärschlüsseln im Allgemeinen als überlegen gegenüber ROW_NUMBER( ) Problemumgehung. Es macht nicht nur komplexe Berechnungen überflüssig, sondern verbessert auch die Parallelität und Datenintegrität, indem sichergestellt wird, dass jede Zeile eine eindeutige und nicht widersprüchliche ID hat.
Das obige ist der detaillierte Inhalt vonWie kann ich Daten ohne Identitätsspalte mit ROW_NUMBER() automatisch erhöhen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!