更好使用ADO.NET访问技术说明

开发 后端
而数据绑定技术则能够把ADO.NET访问"改造"成DbTextBox组件,把Label组件"改造"成DbLabel组件等等。所有这些都与DataSet有直接关系。

这就是我们的.NET支持。我们的方向是提供一个全面的功能访问。所以对你这个问题的回答是肯定的。我们将根据我们用户的需要支持.NET,看看在Oracle技术网站上Windows开发中心提供的所有内容吧。ADO.NET访问我们是很积极主动的。

如果仅仅检索数据,并不需要更新数据,则可以通过使用MergeOption.NoTracking 取消变更跟踪。这样,就不会使用ObjectStateManager,减少执行查询的时间,所有返回的实体将是分离的状态(detached state)。在ASP.NET web application 或在WinForms / WPF Grids 控件中以只读方式显示数据时,NoTracking 是一个比较好的选择。
 
在使用对象服务(Object Services)和ADO.NET访问时,需要调用ObjectQuery 的一个重载构造函数,其中第三个参数是MergeOption 枚举。默认的行为是 AppendOnly,可以改变为 NoTracking。

  1. Product product1 = context.Product.FirstOrDefault(p => p.ProductID == 1004);  
  2. if (product1 != null)  
  3. {  
  4. product1.Color = "Black";  
  5. product1.StandardCost = 20;  
  6. product1.ListPrice = 25;  
  7. }  
  8.    
  9. var objectStateEntries = context.ObjectStateManager.GetObjectStateEntries(EntityState.Modified);  
  10.    
  11. foreach (var entry in objectStateEntries)  
  12. {  
  13. Console.WriteLine("{0} - {1} - {2}",  
  14. entry.EntityKey.EntityContainerName,  
  15. entry.EntityKey.EntitySetName.ToString(),  
  16. entry.EntityKey.EntityKeyValues.First().Key + " = " +  
  17. entry.EntityKey.EntityKeyValues.First().Value);  
  18.    
  19. for (int i = 0; i < entry.OriginalValues.FieldCount; i++)  
  20. {  
  21. Console.WriteLine("\t {0} -> {1}", entry.OriginalValues[i], entry.CurrentValues[i]);  
  22. }  

在下面的示例中,首先检索特定的Product记录,修改其中3个属性,并调用GetObjectStateEntries(EntityState.Modified) 方法,返回所有更新实体的列表,并进一步遍历ObjectStateEntry集合,显示实体名称,ADO.NET访问,初始值和当前值。

责任编辑:chenqingxiang 来源: 51cto
相关推荐

2009-12-24 11:04:21

ADO.Net技术

2009-12-22 16:23:26

ADO.NET访问

2009-12-22 17:43:26

ADO.Net技术

2009-12-21 16:53:06

ADO.NET使用说明

2009-11-04 17:22:30

ADO.NET数据访问

2009-12-21 14:39:09

ADO.NET技巧

2009-12-18 14:20:26

ADO.NET组件

2009-12-23 15:13:15

Ado.Net Syb

2009-12-24 10:37:03

ADO.NET访问数据

2009-12-24 13:38:07

ADO.NET技术

2009-12-31 15:39:46

ADO.NET访问数据

2009-12-31 09:54:04

ADO.NET数据访问

2009-12-21 14:55:49

ADO.NET对象

2009-12-18 15:11:50

ADO.NET类

2009-12-22 10:43:48

ADO.NET类库

2009-12-18 13:52:39

ADO.NET设计器

2009-12-29 13:57:30

访问ADO.NET

2009-12-23 09:26:56

ADO.NET属性

2009-12-24 09:34:47

调用ADO.NET

2009-12-21 17:29:43

ADO.NET模型
点赞
收藏

51CTO技术栈公众号