将不确定变为确定~Linq to SQL不能随机排序吗?

回到目录

一般来说,在T-SQL时代,随机排序可以进行newid()产生出guid值来实现,代码一般为:

SELECT   TOP   10   *   FROM User ORDER   BY   NEWID ();

而到了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,比较简单,就不举例子了。

 回到目录

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值