首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >到实体的Linq -参考EntityKey

到实体的Linq -参考EntityKey
EN

Stack Overflow用户
提问于 2011-11-01 16:40:23
回答 1查看 770关注 0票数 0

现在我已经建立了一个数据库。

Visual Studio2008SP1的ADO.NET实体框架生成了一个类似如下的实体模型:http://img835.imageshack.us/img835/1810/carease15test1ef.png

我创建了一个方法,方法如下:

代码语言:javascript
复制
    private void buttonAddPatient_Click(object sender, EventArgs e)
    {
        using (carease15test1Entities context = new carease15test1Entities())
        {
            long bnumber = Convert.ToInt32(textBoxToBed.Text);
            long rnumber = Convert.ToInt32(textBoxOfRoom.Text);

            long bid = (from b in context.bed
                        where b.bnumber == bnumber
                        select b.bid).First();

            long rid = (from r in context.room
                        where r.rnumber == rnumber
                        select r.rid).First();

            // Create a new bed, and input its details.
            patient p = new patient();
            p.pname = textBoxPatient.Text;
            p.Bed_bid = bid;
            p.bedReference.EntityKey = new EntityKey("carease15test1Entities.bed", "bid", bid);
            p.Bed_Room_rid = rid;
            p.bed.roomReference.EntityKey = new EntityKey("carease15test1Entities.room", "rid", rid);

            context.AddTopatient(p);
            try
            {
                context.SaveChanges();
            }
            catch (OptimisticConcurrencyException ex)
            {
                // Resolve the concurrency conflict by refreshing the // object context before re-saving changes. 
                context.Refresh(System.Data.Objects.RefreshMode.ClientWins, p);
                // Save changes.
                context.SaveChanges();
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
    }

所有东西都运行得很好,除了

p.bed.roomReference.EntityKey =新EntityKey("carease15test1Entities.room","rid",rid);

结果是一个NullRefenceException提示“object reference not set to a instance of an object”。

这是我的项目文件。

http://www.mediafire.com/?w3rjjbxbxw6wacv

有人能帮我一下吗?

非常感谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-11-01 18:30:49

你应该这样做

代码语言:javascript
复制
p.bedReference.Load()

以便加载p.bed的内容。

附注:如果您可以升级到.NET 4.0,它将自动为您完成。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7964132

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档