[英]Why doesn't my C# code update the SQL Server database although I get the correct number of affected rows
[英]Why Doesn't my Code Update The database?
看看这两个代码
第一:
Slide _Slide = DataContext.Slides.SingleOrDefault(rec => rec.Id == _SlideObj.Id); _Slide = _SlideObj; DataContext.SaveChanges();
第二:
Slide _Slide = DataContext.Slides.SingleOrDefault(rec => rec.Id == _SlideObj.Id); _Slide.Title = _SlideObj.Title; _Slide.Description = _SlideObj.Description; DataContext.SaveChanges();
第一个代码不会更新数据库,而是第二个更新。 为什么? 如何更改我的代码以在第一种方法中执行更新操作? (我喜欢用第一种方法)
第一个仅将变量的值更改为不同的引用。 它实际上不会以任何方式更新对象 。 数据上下文正在跟踪对象 。
没有更新,因为您没有更改任何内容。 在第一种情况下,您只需将_Slide
更改为指向其他幻灯片。
第一种方法的问题是设计上的,与您正在使用的框架无关。
通过调用:_Slide = _SlideObj;
你告诉_Slide指向_SlideObj,但是在内存中,前一个指向_Slider的指针的Title和Description属性保持不变。
因此,这是正常行为。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.