zoukankan      html  css  js  c++  java
  • 於 LINQ to Entity 中隨機取得 N 筆資料

    在 SQL Server 中我們可以利用 ORDER BY NewID() 搭配 TOP(如下列 T-SQL 敘述)來做到類似隨機抽樣的效果。

       1:  use Northwind
       2:  go
       3:  
       4:  select top 20 *
       5:  from customers
       6:  order by NEWID()

    若您想要利用 LINQ to Entity 來做到相同的效果,可以使用 orderby 子句搭配 Guid.NewGuid 來產生亂數的結果,最後再使用 Take 方法來取得前幾筆資料,類似下列的程式碼:

       1:              using (NorthwindEntities context = new NorthwindEntities())
       2:              {
       3:                  var query = from p in context.Customers
       4:                              orderby Guid.NewGuid()  //利用orderby Guid的方式來打亂資料
       5:                              select p;
       6:                  for (int i = 0; i < 3; i++)
       7:                  {
       8:                      foreach (var item in query.Take(20)) //利用Take方法取得前20筆資料
       9:                      {
      10:                          Console.WriteLine(item.CustomerID);
      11:                      }
      12:                      Console.WriteLine("-----------------------------");
      13:                  }
      14:              }
      15:              Console.Read();

    執行結果如下:

    image

  • 相关阅读:
    第一阶段大作业 文件上传格式
    第一阶段大作业 数据字典的修改
    设计模式 C++实现职责链模式 (顺便复习C++)
    Numpy学习
    2019版:第二章:(1)Redis 概述
    第一章:(6)Dubbo 与 SpringBoot 整合
    第一章:(5)Dubbo 监控中心
    2019版:第一章:(2)NOSQL 数据库
    2019版:第二章:(3)Redis 其他相关知识
    2019版:第一章:(1)技术发展
  • 原文地址:https://www.cnblogs.com/zcm123/p/3113954.html
Copyright © 2011-2022 走看看