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"中所论及的麻烦.