Linq To Entities - 过滤列表

时间:2016-11-06 18:59:04

标签: c# sql entity-framework linq linq-to-entities

我真的很想为某些特定数据使用某种形式的过滤方法。过滤设备(请参阅下面的课程)而不必担心对孩子List<DeviceQueue>进行过滤可以完美地按预期工作。但是,当我尝试过滤说MessageId和/或SequenceId时,结果将返回MessageQueue表中的所有条目,忽略我的过滤器。

请参阅设备的Data.Model:

public class Device : EntityBase
{
    public string SerialNumber { get; set; }
    public virtual DeviceType DeviceType { get; set; } 
    public virtual List<DeviceQueue> MessageQueue { get; set; }
}

请参阅DeviceQueue的Data.Model:

public class DeviceQueue : EntityBase
{
    public string MessageId { get; set; }
    public Int32 SequenceId { get; set; }

请参阅过滤方法(在第一个建议的答案后更新):

        public IQueryable<Device> Filter(IQueryable<Device> device)
    {

        IQueryable<DeviceQueue> deviceQueue = Enumerable.Empty<DeviceQueue>().AsQueryable();

        //Because it is IQueryable, the data is not fetched until you bind it so it only pulls the data you need.
        if (DeviceId != null)
        {
            device = device.Where(d => d.Id == DeviceId);
        }

        if (SequenceId != null)
        {
            device = device.Where(d => d.MessageQueue.Any(q => q.SequenceId == SequenceId.Value));
        }

        if (MessageId != null)
        {
            device = device.Where(d => d.MessageQueue.Any(q => q.MessageId == MessageId));
        }

        return device;
    }

1 个答案:

答案 0 :(得分:1)

您可以按如下方式添加谓词:

 if (SequenceId.HasValue)
 {
     device = device.Where(d => d.MessageQueue
                        .Any(q => q.SequenceId == SequenceId.Value));
 }

MessageId相同。