Linq to Entities - 参考EntityKey

时间:2011-11-01 08:40:23

标签: linq entity-framework linq-to-entities entitykey

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

Visual Studio 2008 SP1的ADO.NET实体框架已生成如下的实体模型: http://img835.imageshack.us/img835/1810/carease15test1ef.png

我创建了一个方法如下:

    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 = new EntityKey(“carease15test1Entities.room”,“rid”,rid);

结果是NullRefenceException说“对象引用没有设置为对象的实例。”

这是我的项目文件。

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

有人能给我一些帮助吗?

非常感谢你。

1 个答案:

答案 0 :(得分:0)

你应该做

p.bedReference.Load()

这样就加载了p.bed的内容。

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