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"中所论及的麻烦.
免责声明: 本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
◆◆◆刚才面试了一个人,NET方面的,说一下情况,大家帮小弟我看看能不能要~
点击按钮两次才弹出确认对话框的小有关问题,不要在page_load()预先先加载按钮事件的解决办法
ASP.NET 2.0数据处理之高级分页/排序
SQL多条件查询控制解决方案
在word中如何控制graph控件
简单的array 数组有关问题 , 急
用户下载文件后,Response.End()报错?该如何处理
为什么只返回了一个值?而不是一个数组?解决办法
·DataSet.Tables[0].Select()是什么意思?该怎么处理
mvc3中如何用DataType验证格式没有效果
DropDownList有关问题
关于页面信息保存的有关问题,请各位
关于gridview绑定2个SQL数据表的有关问题
像CSDN一样,页面框架先显示,然后再加载内容,如何实现的,多谢
asp.net2.0 中怎么动态变改GridView的数据源组件
服务器控件跟非服务器控件在javascript调用里有什么不同吗
后缀名 .ashx的使用解决办法
与“string.Split(params char[])”最匹配的重载方法具有一些无效参数,该怎么解决
网页无法显示解决方法
between A and B, 不能得到 A和B,如何才能取到 A,B在内的所有符合的值