linq 如何将两张表读取后赋值到实体对象的属性

qq_32395957 2016-09-08 09:55:39
有两张表UserBase和UserInfo为一对一关系,实体类分别如下

public class UserBase
{
/// <summary>
/// Id
/// </summary>
[DataMember]
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int Id { get; set; }
/// <summary>
/// UserName
/// </summary>
[DataMember]
public string UserName { get; set; }
/// <summary>
/// PassWord
/// </summary>
[DataMember]
public string PassWord { get; set; }

[DataMember]
[NotMapped]
public UserInfo UserInfo { get; set; }//对应子表
}

public class UserInfo
{
/// <summary>
/// UserId 和主表的主键对应
/// </summary>
[DataMember]
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.None)]
public int UserId { get; set; }
/// <summary>
/// Name
/// </summary>
[DataMember]
public string Name { get; set; }
/// <summary>
/// Sex
/// </summary>
[DataMember]
public bool Sex { get; set; }
}


linq 的代码如下

public List<UserBase> UserBase_List()
{
var context = new DataContext();
var query = from a in context.Set<UserBase>()
join b in context.Set<UserInfo>()
on a.Id equals b.UserId
select a;//这样只能获取到UserBase的信息,UserBase.UserInfo无法赋值
//select new UserBase{Id = a.Id, UserInfo = b} 如果这样写,会报错“The entity or complex type 'Model.UserBase' cannot be constructed in a LINQ to Entities query”
return query.ToList();
}

请问怎么写linq?
...全文
247 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
ArmStronger 2016-09-08
  • 打赏
  • 举报
回复
select new {Id = a.Id, UserInfo = b}

62,041

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧