您的位置:首页 > 数据库

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

2013-01-06 17:30 330 查看
回到目录

一般来说,在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非要找个实现的方法,可以在当前数据上下文类中,加个函数:(注意,我们为了扩展性,最要新建一个分

部来做这事)

  /// <summary>
/// 数据上下文扩展
/// </summary>
public partial class dbDataContext
{
/// <summary>
/// 随机排序
/// </summary>
/// <returns></returns>
[Function(Name = "NewID", IsComposable = true)]
public Guid NewID()
{
return ((Guid)(this.ExecuteMethodCall(this, ((MethodInfo)(MethodInfo.GetCurrentMethod())))
                                                   .ReturnValue));

}
}


具体扩展代码:

from user in db.User order by db.NewID() select user


如果希望按着某个字符串中字符出现的次序,进行特定的排序,可以使用IndexOf,代码如下:

List<string> productids={"1","2","3"};
linq.ToList().OrderByDescending(a => productids
.IndexOf(a.MC_ProductID))
.ToList();


有时,我们要为多个字段进行主要,次要的排序,这时,可以用linq自带的ThenBy,比较简单,就不举例子了。

回到目录
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: