【发布时间】:2020-02-01 15:12:49
【问题描述】:
我在 ASP.NET Core API 项目中有 User、Contact 和 ContactOfUser 实体。我想根据这些表的输入过滤用户。
我的实体类是这样的:
public class User
{
public int Id { get; set; }
[MaxLength(50)]
public string Name { get; set; }
[MaxLength(50)]
public string Surname { get; set; }
[MaxLength(60)]
public string Username { get; set; }
}
public class Contact
{
public int Id { get; set; }
[MaxLength(50)]
public string Value{ get; set; }
}
public class ContactOfUser
{
public int Id { get; set; }
public int UserId { get; set; }
[ForeignKey(nameof(UserId))]
public User User { get; set; }
public int ContactId { get; set; }
}
我想根据这个FilterModel 对象过滤用户:
public class FilterModel
{
public string Name { get; set; }
public string Surname { get; set; }
public string Username { get; set; }
public List<int> ContactId { get; set; }
}
考虑到当数据被接受为空时不应用特殊过滤器数据,我如何使用 Linq 方法在实体框架中进行此过滤过程?
我做了类似的方法,但它不能正常工作:
List<User> GetFilteredUsers(FilterModel filter)
{
var query1 = dbContext.Users
.Where(u => u.Name.Contains(filter.Name ?? string.Empty) &&
u.Surname.Contains(filter.Surname ?? string.Empty) &&
u.Username.Contains(filter.Username ?? string.Empty));
var query2 = from u in query1
join cu in dbContext.ContactOfUsers on u.Id equals cu.UserId
into res
from item in res.DefaultIfEmpty()
where filter.Contacts.Contains(item.ContactId)
select new InitialUserModel
{
Id = u.Id,
Name = u.Name,
Surname = u.Surname,
Username = u.Username
};
}
【问题讨论】:
-
到目前为止你尝试了什么?
-
经常看到,您不使用导航属性。而这个
FilterModel的作用是什么?你最好展示你自己的努力,无论多么尝试,以阐明其预期用途。
标签: sql entity-framework asp.net-core