ホームページ > データベース > mysql チュートリアル > MySQL テーブルから重み付きランダム エントリを選択するにはどうすればよいですか?

MySQL テーブルから重み付きランダム エントリを選択するにはどうすればよいですか?

Linda Hamilton
リリース: 2024-12-03 06:26:10
オリジナル
189 人が閲覧しました

How Can I Select a Weighted Random Entry from a MySQL Table?

MySQL での加重ランダム エントリの選択

この質問は、「乗数」列。各エントリは、この列の値に基づいて重み付けされます。値 0 は重み付けなし、1 は重み付けが二重であることを示します。

ユーザーは、SELECT と RAND() を使用して提供されたコードを変更しようとします。

解決策は、 で提案されているように、ORDER BY -LOG(1.0 - RAND()) / Multiplier を使用することです。同様のスタック オーバーフロー スレッド。この式は、乗数の値に基づいてエントリに効果的に重み付けを行い、正確な結果を生成します。

ただし、このアプローチには制限があります。乗数を 0 に設定すると、ゼロによる除算エラーが発生します。これを軽減するには、WHERE 句を使用して Multiplier 値が 0 より大きいエントリを除外できます。

以上がMySQL テーブルから重み付きランダム エントリを選択するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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