首页 | 电子商务新闻 | 电子商务研究 | 电子商务学院 | 电子商务法规 | 电子商务就业 | 电子商务图片 | 会员登录 | 会员投稿
 当前位置:首页>>电子商务学院>>建站技术>>.NET>>正文
ADO.NET入门(4)
文章出处:  作者:  发布时间:2006-04-12
电子商务论坛 文字链广告招租 文字链广告招租 把此文收藏到您的网摘中:
  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"中所论及的麻烦.
[返回顶部↑]  [推荐好友] [查看评论]  
用户名: 新注册) 密码: 匿名评论 [查看评论]  发表评论
评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
 
↑文章搜索
  关键字:  
  范  围:  
  开始搜索  
※相关文章※
 

◎ADO.NET入门(2)
◎ADO.NET入门(3)
◎ADO.NET入门(1)
◎取得客户端浏览器的信息
◎从资料源取回第二个DataTa
◎如何用UltraEdit编译C#源程
◎在C#中操作XML (增删改)

 
※本站广告※
   
※热点文章※
  ·带你走进ASP.NET(4)
·带你走进ASP.NET(1)
·如何用UltraEdit编译C#源程
·带你走进ASP.NET(2)
·带你走进ASP.NET(3)
·使用ASP.NET开发移动通讯的
·ASP.NET虚拟主机的重大安全
 
· 中国电子商务信息港各地代表处子站 ·
广东 - 深圳 - 山东 - 江苏 - 浙江 - 辽宁 - 上海 - 陕西 - 天津 - 北京 - 内蒙古 - 河北 - 湖北 - 河南 - 四川 - 重庆
福建 - 吉林 - 山西 - 甘肃 - 新疆 - 安徽 - 江西 - 广西 - 湖南 - 贵州 - 云南 - 宁夏 - 海南 - 西藏 - 青海 - 黑龙江
版权所有:中国电子商务信息港 建设运营:荆门鑫源互联网络科技有限公司
信息产业部ICP备案编号:鄂ICP备05005878号 ‖ 公安局网监备案编号:WZ4208020071
本站中文全称:中国电子商务信息港中国电子商务信息港黑板报