Heim >Datenbank >MySQL-Tutorial >Wie kann ich effizient einen zufälligen Prozentsatz von Zeilen in SQL Server auswählen?
Vereinfachte zufällige Zeilenauswahl in SQL Server: Ein optimierter Ansatz
SQL Server-Benutzer müssen häufig eine zufällige Stichprobe von Zeilen aus einer Tabelle auswählen. Die Suche nach einer sauberen und effizienten Methode hierfür war in der Vergangenheit problematisch. Dieser Artikel stellt eine vereinfachte Lösung vor.
Frühere Versuche beinhalteten oft komplexe temporäre Tabellen und iterative Prozesse. Obwohl die NEWID()
-Funktion Potenzial bietet, erwies sich die zuverlässige Auswahl eines genauen Prozentsatzes als schwierig.
Hier ist eine prägnante und effiziente Lösung:
<code class="language-sql">SELECT TOP 10 PERCENT * FROM [yourtable] ORDER BY NEWID()</code>
Diese Abfrage verwendet ORDER BY NEWID()
, um die Zeilen zufällig zu mischen. TOP 10 PERCENT
wählt dann die oberen 10 % dieser gemischten Zeilen aus.
Für sehr große Tabellen empfiehlt sich ein leistungsoptimierter Ansatz:
<code class="language-sql">SELECT * FROM [yourtable] WHERE [yourPk] IN (SELECT TOP 10 PERCENT [yourPk] FROM [yourtable] ORDER BY NEWID())</code>
Dieser Ansatz wählt zunächst mithilfe einer Unterabfrage eine zufällige Stichprobe von Primärschlüsselwerten aus. Die Hauptabfrage ruft dann nur die Zeilen ab, die diesen Schlüsseln entsprechen. Dies reduziert die gescannten Daten erheblich und steigert die Leistung.
Diese Techniken bieten eine einfache und effektive Möglichkeit, eine zufällige Zeilenauswahl in SQL Server durchzuführen und so ein zuvor komplexes Problem zu lösen.
Das obige ist der detaillierte Inhalt vonWie kann ich effizient einen zufälligen Prozentsatz von Zeilen in SQL Server auswählen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!