一、问题描述

  在EF中使用随机排序出现的问题:LINQ to Entities does not recognize the method 'System.Guid NewId()' method, and this method cannot be translated into a store expression .

  解释就是:在使用 LINQ TO Entities 中生成的 sql 语句中找不到该 System.Guid NewId() 方法。毕竟在 sql 中确实不存在该函数。

二、解决思路 

  那就是从数据库中取出数据,拿到数据在进行排序,返回到客户端。

第一种使用 Random 随机排序:

var query = BuildQuery(_infoRepository
.GetAll()
.PageBy(input)
.ToListAsync()
Random random = new Random();
var ent = (from q in query  select new { q, r = random.Next(1, 10) });
var t = ent.OrderBy(x => x.r).Select(x => x.q).ToList();

第二种使用 Guid 随机排序:

var query = BuildQuery(_infoRepository
.GetAll();
var querySetTop = query.ToList().OrderBy(x => Guid.NewGuid());

先使用 ToList() 方法表示已经把数据从数据库加载到客户端了,在进行排序就ok了。

最新文章

  1. python基础之day2
  2. Java Web之会话管理二:Session
  3. jquery客户端验证插件
  4. ECMAScript 6教程 (一)
  5. Jqueryの锋利的jquery练习
  6. R统计图
  7. 分享一个自己用的Objective-C的Http接连类
  8. css居中技巧
  9. spring中连接池的配置
  10. cpu卡,sam卡原理
  11. Table 'performance_schema.session_variables' doesn't exist错误的一
  12. PHP中cURL的应用
  13. spark-sql(spark sql cli)客户端集成hive
  14. 中间件之Kafka
  15. python之使用heapq()函数计算列表中数值大小
  16. MGW PCI Framework Architecture
  17. 使用Samba实现文件共享
  18. 华为手机使用objectAnimation异常
  19. git 使用备忘
  20. 十九、curator recipes之PathChildrenCache

热门文章

  1. multiple-value uuid.NewV4() in single-value context
  2. 【题解】 P5021赛道修建
  3. 我的Java开发学习之旅------>在Dos环境下Java内部类的编译和运行
  4. 关于调用notifyDataSetChanged刷新PullToRefreshListView列表无反应解决办法
  5. (转)nginx-rtmp-module和ffmpeg搭建实时HLS切片
  6. 世界各国Google网址大全
  7. kvm初体验之三:vm的安装及管理
  8. ZOJ 3805 Machine(二叉树,递归)
  9. listen 76
  10. listen 67