1

我正在尝试在 C# 中使用此代码选择成员类型的实体。我正在看一个视频教程,他们也是这样做的,但它对我不起作用。

        Member member = new Member();
        var query =  from m in db.Members  where Member.MemberID == textBox1.Text 
        select m;     
        var currentMember =  query.FirstOrDefault();
        string CurrentID = M.MemberID;    

没有例外或东西,但我得到所有 currentMember 的属性都是空的。有什么想法可以得到预期的结果吗?

4

2 回答 2

1

我想你可能会在这里混淆你的变量。让我们尝试清理这段代码:

var memberQuery = from m in db.Members
                  where m.MemberID == textBox1.Text
                     // ^ you need to reference the MemberID by the query
                     //   variable (m) not the class name (Member).
                  select m;

var member = memberQuery.SingleOrDefault();
                      // ^ when you only expect zero or one records from the
                      //   database, use SingleOrDefault instead of
                      //   FirstOrDefault, because it will throw an exception
                      //   when more than one record is returned.

if (member != null)
 // ^ always check to make sure that the database returned a value before trying
 //   to access any fields on the object.
{
    string currentId = member.MemberID;
}
else
{
    // a member with the given ID doesn't exist in the database
}
于 2013-01-12T22:18:10.067 回答
0

问题出在where Member.MemberID == textBox1.Text

应该是where m.MemberID == textBox1.Text

为什么要创建会员?Member member = new Member();

只需从查询中获取成员并从中获取 id。

于 2013-01-12T22:21:00.657 回答