Heim >Datenbank >MySQL-Tutorial >Wie kann ich Daten ohne Identitätsspalte mit ROW_NUMBER() automatisch erhöhen?

Wie kann ich Daten ohne Identitätsspalte mit ROW_NUMBER() automatisch erhöhen?

DDD
DDDOriginal
2025-01-04 21:53:40860Durchsuche

How Can I Auto-Increment Data Without an Identity Column Using ROW_NUMBER()?

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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn