现在我已经建立了一个数据库。
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
谁能给我一些帮助?
非常感谢。