将不确定变为确定~Linq to SQL不能随机排序吗?
一般来说,在T-SQL时代,随机排序可以进行newid()产生出guid值来实现,代码一般为:

而到了linq to sql时代,由于产生的语句为延时的(可能是这个原因),所以你用类似这代码:
from user in db.User order by Guid.NewID() select user
是不能实现的,这时,如果你的linq to sql非要找个实现的方法,可以在当前数据上下文类中,加个函数:(注意,我们为了扩展性,最要新建一个分
部来做这事)
1 /// <summary> 2 /// 数据上下文扩展 3 /// </summary> 4 public partial class dbDataContext 5 { 6 /// <summary> 7 /// 随机排序 8 /// </summary> 9 /// <returns></returns> 10 [Function(Name = "NewID", IsComposable = true)] 11 public Guid NewID() 12 { 13 return ((Guid)(this.ExecuteMethodCall(this, ((MethodInfo)(MethodInfo.GetCurrentMethod())))
.ReturnValue)); 14 15 } 16 }
具体扩展代码:
from user in db.User order by db.NewID() select user
如果希望按着某个字符串中字符出现的次序,进行特定的排序,可以使用IndexOf,代码如下:
1 List<string> productids={"1","2","3"}; 2 linq.ToList().OrderByDescending(a => productids 3 .IndexOf(a.MC_ProductID)) 4 .ToList();
有时,我们要为多个字段进行主要,次要的排序,这时,可以用linq自带的ThenBy,比较简单,就不举例子了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示
2012-01-06 基础才是重中之重~用好“逻辑与”和“逻辑或”,可以让你的程序更优美!