C# 随机列表
2024-10-21 13:03:33
一、问题描述
在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了。
最新文章
- python基础之day2
- Java Web之会话管理二:Session
- jquery客户端验证插件
- ECMAScript 6教程 (一)
- Jqueryの锋利的jquery练习
- R统计图
- 分享一个自己用的Objective-C的Http接连类
- css居中技巧
- spring中连接池的配置
- cpu卡,sam卡原理
- Table 'performance_schema.session_variables' doesn't exist错误的一
- PHP中cURL的应用
- spark-sql(spark sql cli)客户端集成hive
- 中间件之Kafka
- python之使用heapq()函数计算列表中数值大小
- MGW PCI Framework Architecture
- 使用Samba实现文件共享
- 华为手机使用objectAnimation异常
- git 使用备忘
- 十九、curator recipes之PathChildrenCache
热门文章
- multiple-value uuid.NewV4() in single-value context
- 【题解】 P5021赛道修建
- 我的Java开发学习之旅------>在Dos环境下Java内部类的编译和运行
- 关于调用notifyDataSetChanged刷新PullToRefreshListView列表无反应解决办法
- (转)nginx-rtmp-module和ffmpeg搭建实时HLS切片
- 世界各国Google网址大全
- kvm初体验之三:vm的安装及管理
- ZOJ 3805 	Machine(二叉树,递归)
- listen 76
- listen 67