将不确定变为确定~Linq to SQL不能随机排序吗?
2013-01-06 17:30
330 查看
回到目录
一般来说,在T-SQL时代,随机排序可以进行newid()产生出guid值来实现,代码一般为:
SELECT TOP 10 * FROM User ORDER BY NEWID();
而到了linq to sql时代,由于产生的语句为延时的(可能是这个原因),所以你用类似这代码:
是不能实现的,这时,如果你的linq to sql非要找个实现的方法,可以在当前数据上下文类中,加个函数:(注意,我们为了扩展性,最要新建一个分
部来做这事)
具体扩展代码:
如果希望按着某个字符串中字符出现的次序,进行特定的排序,可以使用IndexOf,代码如下:
有时,我们要为多个字段进行主要,次要的排序,这时,可以用linq自带的ThenBy,比较简单,就不举例子了。
回到目录
一般来说,在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,比较简单,就不举例子了。
回到目录
相关文章推荐
- Linq to Sql 随机查询
- 将不确定变为确定~LINQ查询包含对不同数据上下文上所定义项的引用
- 将不确定变为确定~真的是SqlDataReader引起的超时?
- 关于linq to sql 或linq to entity 随机取数据
- linq to sql 学习(5)关于排序的介绍
- EF架构~linq to entity的随机排序问题
- linq to sql取出随机记录/多表查询/将查询出的结果生成xml
- linq to sql 查询后排序(字符串类型的数字进行排序)
- linq to sql取出随机记录/多表查询/将查询出的结果生成xml
- Linq to SQL: 自定义排序
- linq to sql Attach 不能添加其键已在使用中的实体
- 将不确定变为确定~Linq-Distinct()方法是否可以对复杂结果集进行去重?
- 将不确定变为确定系列~Linq的批量操作靠的住吗?
- Linq to SQL 不能更新xml字段
- 将不确定变为确定~Linq的Group是否可以根据多个字段进行分组
- LINQ to SQL语句Order By,排序
- linq to sql 不能更新的问题
- [Silverlight][linq to sql]不能找到linq to sql自动生成类型
- 转:使用linq to sql 随机取一行数据的方法
- Lambda动态附加条件和排序语句 (可用于linq to sql)