博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C# 随机列表
阅读量:7083 次
发布时间:2019-06-28

本文共 833 字,大约阅读时间需要 2 分钟。

一、问题描述

  在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了。

 

转载于:https://www.cnblogs.com/gzbit-zxx/p/10633730.html

你可能感兴趣的文章
整合资源这门生意并没那么好做
查看>>
Windows从noinstall zip安装MySQL免安装版
查看>>
在这里驻扎!
查看>>
我的友情链接
查看>>
我的友情链接
查看>>
我的友情链接
查看>>
一入IOS告别Win
查看>>
解: Eclipse+pydev中文显示
查看>>
python ,序列,得到所有元素索引及值
查看>>
自动填写表单有风险吗?
查看>>
JSON下载与解析
查看>>
我的友情链接
查看>>
react+react-router+redux+react-redux构建一个简单应用
查看>>
二叉树遍历 (先序遍历、中序遍历、后序遍历) 递归
查看>>
shell编程学习之sed
查看>>
centos7/rhel7的与众不同系列(2)——如何配置vncserver
查看>>
windows server 2012安装后规划分区
查看>>
Python学习笔记(2)--Python的安装
查看>>
使用cygwin/openSSH搭建windows下的SSH服务器
查看>>
Ubuntu里网卡IP设置的步骤&/etc/passwd文件
查看>>