[解決済み] LinqからSqlへのランダム行
2022-05-15 19:12:54
質問
Linq to SQLを使用して、あるフィールドがtrueでなければならないなどの条件があるときに、ランダムな行を取得するための最良の(そして最も速い)方法は何でしょうか?
どのように解決するのですか?
データベースで、偽のUDFを使用することによって、これを行うことができます。部分クラスで、データコンテキストにメソッドを追加してください。
partial class MyDataContext {
[Function(Name="NEWID", IsComposable=true)]
public Guid Random()
{ // to prove not used by our C# code...
throw new NotImplementedException();
}
}
次に、ただ
order by ctx.Random()
これは SQL-Server でランダムな順序付けを行うものです。
NEWID()
のおかげで SQL-Server でランダムな順序になります。
var cust = (from row in ctx.Customers
where row.IsActive // your filter
orderby ctx.Random()
select row).FirstOrDefault();
これは小規模から中規模のテーブルにのみ適していることに注意してください。巨大なテーブルでは、サーバーでのパフォーマンスに影響が出るので、行数を求める方が効率的です(
Count
)、それから無作為に一つを選び (
Skip/First
).
をカウントアプローチに使用します。
var qry = from row in ctx.Customers
where row.IsActive
select row;
int count = qry.Count(); // 1st round-trip
int index = new Random().Next(count);
Customer cust = qry.Skip(index).FirstOrDefault(); // 2nd round-trip
関連
-
[解決済み] LINQ: フィルタリング基準で SingleOrDefault と FirstOrDefault() を使用する場合
-
[解決済み] C#の正しいバージョン番号を教えてください。
-
[解決済み] 乱数(int)を生成する方法を教えてください。
-
[解決済み] Try-catchは私のコードをスピードアップさせるか?
-
[解決済み] なぜList<T>を継承しないのですか?
-
[解決済み] 特定のプロパティに対するLINQのDistinct()
-
[解決済み] SelectとSelectManyの違い
-
[解決済み] C#で文字を繰り返し表示する最適な方法
-
[解決済み] Entity FrameworkとLINQ to SQLの比較
-
[解決済み】大文字・小文字を区別しない「Contains(string)
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】文字列が有効な DateTime " format dd/MM/yyyy " として認識されなかった。
-
[解決済み] エンティティタイプ <type> は、現在のコンテキストのモデルの一部ではありません。
-
[解決済み】SmtpException: トランスポート接続からデータを読み取れません:net_io_connectionclosed
-
[解決済み】非静的メソッドはターゲットを必要とする
-
[解決済み】MetadataException: 指定されたメタデータ・リソースをロードできない
-
[解決済み] EntityTypeにキーが定義されていないエラー
-
[解決済み】Unity 「関連するスクリプトを読み込むことができません」「Win32Exception: システムは指定されたファイルを見つけることができません"
-
[解決済み】Entity FrameworkからのSqlException - セッション内で他のスレッドが動作しているため、新しいトランザクションは許可されません。
-
[解決済み】ファイルへの読み書きの際に共有違反のIOExceptionが発生する C#
-
[解決済み】WebResource.axdとは何ですか?