• 将不确定变为确定~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,比较简单,就不举例子了。

     回到目录

  • 相关阅读:
    jQuery使用经验建议
    java的各种类型转换汇总
    二路归并排序算法实现-完整C语言程序
    Java连接MYSQL 数据库的连接步骤
    二叉树
    bat命令批量创建文件夹
    【转】Android原生PDF功能实现
    【转】Android root检测方法总结
    【转】Android 破解视频App去除广告功能详解及解决办法总结
    【转】什么是微信62数据,62数据脚本有什么用?
  • 原文地址:https://www.cnblogs.com/lori/p/2848052.html
Copyright © 2020-2023  润新知