ホームページ > データベース > mysql チュートリアル > SQL Server でランダムな割合の行を効率的に選択するにはどうすればよいですか?

SQL Server でランダムな割合の行を効率的に選択するにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2025-01-19 08:17:09
オリジナル
361 人が閲覧しました

How Can I Efficiently Select a Random Percentage of Rows in SQL Server?

SQL Server での単純化されたランダム行選択: 合理化されたアプローチ

SQL Server ユーザーは、テーブルから行のランダムなサンプルを選択する必要が頻繁にあります。 これを行うためのクリーンで効率的な方法を見つけることは、歴史的に困難でした。この記事では、簡略化された解決策を紹介します。

これまでの試みには、複雑な一時テーブルと反復プロセスが含まれることが多かった。 NEWID() 関数には可能性がありますが、正確なパーセンテージを確実に選択することは困難であることが判明しました。

これが簡潔で効率的な解決策です:

SELECT TOP 10 PERCENT * FROM [yourtable] ORDER BY NEWID()
ログイン後にコピー

このクエリは ORDER BY NEWID() を使用して行をランダムにシャッフルします。 TOP 10 PERCENT は、これらのシャッフルされた行の上位 10% を選択します。

非常に大きなテーブルの場合は、パフォーマンスを最適化したアプローチをお勧めします。

SELECT * FROM [yourtable] WHERE [yourPk] IN (SELECT TOP 10 PERCENT [yourPk] FROM [yourtable] ORDER BY NEWID())
ログイン後にコピー

このアプローチでは、まずサブクエリを使用して主キー値のランダムなサンプルを選択します。次に、メイン クエリは、これらのキーに対応する行のみを取得します。これにより、スキャンされるデータが大幅に削減され、パフォーマンスが向上します。

これらの手法は、SQL Server でランダムな行選択を実行する簡単かつ効果的な方法を提供し、これまで複雑だった問題を解決します。

以上がSQL Server でランダムな割合の行を効率的に選択するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート