i know of using the
ORDER BY NEWID()
feature when running a regular sql command. I'm wanting to do the same thing, but via linq2sql.
I'd prefer not to select the whole range, add in a random 开发者_运维百科number via rnd.Next(), and then sort by that...
Marc Gravell posted a solution here that allows you to define a function that uses NEWID in a partial class for the DataContext. Don't place it in the generated DataContext class otherwise future updates would wipe out what you've added.
Marc shows how to use it with the query expression syntax. Alternately, with dot notation, you could write:
var results = dc.Table.OrderBy(r => dc.Random()).Take(n);
In case you're not familiar with creating a partial class, just add a new class to your solution. Its name doesn't matter as long as the class definition uses the DataContext class name with the partial
keyword. For example, if your DataContext is named XYZDataContext
you can add a new class named XYZDataContextPartial.cs
and define it as:
namespace YourNamespace
{
public partial class XYZDataContext
{
}
}
Try the Take
extension method:
.OrderBy(x=>x.NewId)
.Take(randomNumber);
What we're doing here is:
- Order by NewId field in ASC order.
- Select the N first row, where N is the random number.
In case that you want the order to be random, try this:
.OrderBy(x => Guid.NewGuid())
.Take(20);
What we're doing here is:
- Order the list in a random order.
- Take the top 20 rows.
精彩评论