gpt4 book ai didi

c# - Linq帮助-子查询给出空指针异常

转载 作者:行者123 更新时间:2023-11-30 20:42:37 24 4
gpt4 key购买 nike

我正在编写一个电子邮件系统,其中有一个用户表“tblUsers”和一个消息表。一个用户的收件箱中可以有很多消息(来自 tblusers 中的其他用户)(一个:多个)。

在 tblUsers 表中,我有一个名为 ImageURL(字符串)的列,其中包含用户头像的 URL。在这种情况下,我正在循环浏览属于用户的收件箱中的消息,而我想要做的是,一旦我收到消息,就沿着树向上走到 tblUser 并在 ImageURL 列中获取值该消息的所有者在下面标记为“SenderAvatar”。

这是我尝试过的。问题是下面的 SenderAvatar 子 linq 抛出一个空指针异常,即使我已经确认 ImageURL 有一个值(这是开发所以只有三个用户)。不知何故,我的逻辑和 linq 的逻辑在这里不一致。有人可以帮忙吗?谢谢!

编辑我发现了两个错误。第一个错误是 Dzienny 为我指明了比较苹果和橘子的正确方向。第二个错误是 FromUserId = ux.tblUserId, 我将当前用户 ID 设置为 FromUserId 伙计们,感谢您对此的所有帮助。

 public List<UserInboxMsg> GetUserInboxMsg(IKASLWSEntities conx, int userid)
{
var u = (from m in conx.tblUsers where m.Id == userid select m).FirstOrDefault();
if (u != null)
{

return (from ux in u.tblInboxes
orderby ux.CreationTS descending
select new UserInboxMsg
{
CreationTS = ux.CreationTS,
ExpirationDate = ux.ExpirationDate,
FromUserId = ux.tblUserId,
HasImage = ux.HasImage,
ImageId = ux.ImageId ?? 0,
IsDeleted = ux.IsDeleted,
IsRead = ux.IsRead,
MsgId = ux.Id,
MsgSize = ux.MessageSize,
ParentId = ux.ParentId,
Title = ux.Title,
ToUserId = userid,
FromUserName = ux.Title,
SenderAvatar = conx.tblMessages.Where(mu=>mu.Id == ux.Id).FirstOrDefault().tblUser.ImageURL,
Message = ux.Message
}).ToList<UserInboxMsg>();
}
else
{
return new List<UserInboxMsg>();
}
}

}

最佳答案

如果在 Entity Framework 中,两个表之间存在外键引用,您可能会这样做:

SenderAvatar = conx.tblMessages.FirstOrDefault( mu=>mu.Id == ux.Id).ImageURL,

关于c# - Linq帮助-子查询给出空指针异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31223353/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com