ADO.NET入门(4)

原创 2004年02月15日 23:51:00
4.转换现有代码 
   
    大量的ASP页面使用ADO对象来抽取数据.让我们一起来回顾下几例典型的案例,对你在以后处理移植或者改写代码时也许会有帮助。 
   
    如果你有从单个recordset生成报表的ASP页面,那么DataReader会是你的好帮手。 
   
  String strConn, strCmd; 
  strConn = "DATABASE=MyAgenda;SERVER=localhost;UID=sa;PWD=;"; 
  strCmd = "Select * From Names where ID=" + contactID.Text; 
  SQLConnection oCN = new SQLConnection(strConn); 
  SQLCommand oCMD = new SQLCommand(strCmd, oCN); 
  oCN.Open(); 
  SQLDataReader dr; 
  oCMD.Execute(out dr); 
  while (dr.Read()) { 
  // Use dr.GetString(index) or 
  // dr["field name"] to Response.Write data 
  } 
   
    你可以利用HasMoreRows属性来快速检查是否DataReader为空.如果你仅仅只简单处理一系列记录,没有什么比DataReader.更快,更好的对象了,它同样适用于查询单个记录。 
   
    DataReader.的内容是不可编辑的,但你可以将内容移动到更具管理功能的对象里,如: 
   
     DataTable或是一个或多个DataRow 对象. 
   
    当你需要处理表与记录二者之间的复杂关系时,DataReader就不是合适的工具了。数据模型链接越多,SQL命令则会越复杂。导航模块保有连续性,最后放入缓存的数据往往多于你所需要的,. DataSet 和 DataRelation objects是这种表关系模型的基础. 
   
    为管理parent/child 关系,ADO同样也对data-shaping engine进行封装. 总的说来, data shaping 和 ADO .NET 关系是一回事.就设计方面来说,二者几乎没有共同点. Shaped recordsetsct嵌入列表对象中包括了所有数据表信息。ADO.NET关系是动态链接,你可以在两个数据表间随时建立. ADO依靠于Shaping OLE DB service 提供程序,并使用专门的SQL类语言特征以在执行单个ADO命令的过程中生成一个分层的recordset. 
   
    在 ADO.NET 中,关系中涉及的每个对象总是被看成单独的个体。关系本身作为对象被公开,并且具有一定的行为规则。例如,DataRelation 对象可以从父行到子行一层层进行更改。您可以通过将 ForeignKeyConstraint 对象添加到 DataTable 的 Constraints 集合中来进行此操作。ForeignKeyConstraint 对象表示当删除或更新数值和行时,对通过外键关系相关联的一组列的约束。如前面提到的,一旦设置好了关系,在它按程序预设终止之前,您不能进行可能破坏该关系的更改。 
   
    正如早先提到的一样,一旦设置了relationship,除非它是程序性的终止,你不能够对它进行修改,那样会使它突然中断. 
   
    另外, relations没有递延性.你可以在Customers 和Orders之间,Orders 和 Products之间设置两个不同的关系.但是,当为了某个customer而对orders导航时,你不能够从一个order跳到相关的products行.解决方法是,你必须另外打开Orders/Products 关系,锁定你需要的order,然后获取相关的行. 
   
    程序员需要在ASP Session 对中存储记录吗?通过ADO .NET 和 DataSet 对象,你可以非常安全的进行工作,而不会引起在"Storing an ADO Recordset in GIT Might Cause An Access Violation"中所论及的麻烦. 

ADO.NET4从入门到精通/微软技术丛书(奋斗的小鸟)_PDF 电子书

下载地址:
  • tjoy2005
  • tjoy2005
  • 2013年10月09日 14:06
  • 1473

【Ado.Net】基础知识+简单实例

为什么要学Ado.Net?   作为程序员,我们一般都可以在Sql Server 的查询分析器里面查看和操作数据库中的数据。但是普通的用户如果要查看和操作数据库中的数据,在查询分析器里面就不会了,我...
  • Gnd15732625435
  • Gnd15732625435
  • 2017年02月04日 21:59
  • 399

漫谈 ADO.NET之四大核心对象

本人热爱Java,可最终做了c#工作,人生之一大憾事,俗话说,水浅王八多,遍地是大哥,也只好苟存于社会的残垣瓦砾之下! 下面是第一次使用四个“小对象”的具体实现代码 (Oracle 数据库) u...
  • who_is_that
  • who_is_that
  • 2016年06月27日 15:47
  • 502

ADO.NET 基础教程(二)

上一节讲到了怎样使用ADO.NET来查询数据,这节讲怎么样运行SQL的SELECT、INSERT和UPDATE命令及存储过程1、存储过程C#的代码如下:///   /// 存储过程参数结构  /// ...
  • lovelyxc
  • lovelyxc
  • 2005年06月16日 10:25
  • 1701

ADO.NET入门 4

  4.转换现有代码    大量的ASP页面使用ADO对象来抽取数据.让我们一起来回顾下几例典型的案例,对你在以后处理移植或者改写代码时也许会有帮助。    如果你有从单个recordset生成报表的...
  • masterall
  • masterall
  • 2005年09月10日 01:24
  • 757

从零基础入门进行讲解:C#,WINFORM,ADO.NET,ASP.NET的教学视频

从零基础入门进行讲解:   C#,WINFORM,ADO.NET,ASP.NET的教学视频
  • guojun91
  • guojun91
  • 2014年10月13日 11:32
  • 763

ADO.NET数据库应用开发 pdf电子书

内容简介: ADO.NET数据库应用开发详细讲解用ado.net进行数据库开发的方法,分为3篇共12章,包括ado.net、数据库和集成开发环境的基础知识,应用开发的各项技术与方法,用大量实例讲解技...
  • kwworms
  • kwworms
  • 2013年12月05日 00:22
  • 1294

ADO.NET操作数据库(四)

主要内容: 连接查询、左表、右表、内连接、外连接、笛卡尔积、on子句数据筛选、自连接、存储过程、连接查询、模糊查询、视图、T-SQL编程、全局变量、局部变量、事务、系统存储过程、用户自定义存储过程、a...
  • chenrushui
  • chenrushui
  • 2016年11月09日 19:45
  • 1686

《C++入门经典(第4版)》之C++编程总结

C++要比许多人想象的更容易理解。如果你非常渴望学习,并具备逻辑思考的能力,掌握C++就会比想象的更容易。开发C++技巧,学习数百万人已在使用的语言,掌握C++技能,它提供了在几乎任何环境下开发应用程...
  • qinghuawenkang
  • qinghuawenkang
  • 2015年09月08日 10:34
  • 3132

ADO.NET入门

 简介:本文主要讨论了作为实现基本数据库操作方法之一的ADO.NET,以及ADO.NET与ADO的基本比较        ADO.NET将成为构建数据感知 .NET应用程序的基础. 不同于ADO 的是...
  • peter824
  • peter824
  • 2007年06月17日 23:36
  • 302
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ADO.NET入门(4)
举报原因:
原因补充:

(最多只允许输入30个字)