现在我已经建立了一个数据库。
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
有人能给我一些帮助吗?
非常感谢你。
答案 0 :(得分:0)
你应该做
p.bedReference.Load()
这样就加载了p.bed的内容。
P.S。 如果您可以升级到.NET 4.0,它将自动为您完成。