0

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

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 说“对象引用未设置为对象的实例。”</p>

这是我的项目文件。

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

谁能给我一些帮助?

非常感谢。

4

1 回答 1

0

你应该做

p.bedReference.Load()

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

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

于 2011-11-01T10:30:49.360 回答