ASP网页编程之ADO的界说
由于ASP提供的是一对多的服务,所以用户的一些特殊需求很难得到满足。ado在本书前7章中,已报告了ASP的有关内容,和ASP怎样为Web站点带来静态的内容。已见到其剧本程序同意自界说Web页面,使我们可以构立功能更加壮大的ASP页面。
如今,将研讨ASP和数据的集成。固然对用于网页中的剧本数目并没有任何限定,但假如没有某种情势的数据,很快就会进进一个逝世胡同。数据组成了Web站点的实践内容,大概指出了怎样设置Web站点,因而总的说来数据长短常主要的。假如环绕数据存储创建Web站点,改动Web站点时只必要改动响应的数据便可。
ActiveX数据工具(ADO)是同意用户与数据存储举行交互的组件。这意味着只需基于某些数据便可创建一个网页,或一种完整交互的电子商务体系。不管哪一种体例,都是ADO使我们能与数据举行通讯。我们将会商从数据存储猎取和传送数据的次要内容,和失掉数据后的数据处置办法。
起首研讨甚么是ADO及其所包含的组件,然后会商怎样会见数据存储。鄙人一章,将进一步进修ADO更先辈的一些特征,如命令、存储历程和优化使用程序的一些操纵技能。下一步研讨Web服务器和扫瞄器之间的交互历程,和数据处置历程。然后研讨数据存取范畴中极具潜力的XML。XML是甚么?怎样利用?由于XML代表着将来开展的一种趋向,我们将先容微软关于通用数据存取的构思。在这个构思中,数据不但是从数据库中取得的。最初,看一下尺度的微软数据库(如Access与SQLServer)和在个中怎样利用ADO。
本章从ADO入手下手,次要内容有:
·研讨ADO怎样与数据举行交互。
·懂得ADO的组件。
·怎样与数据存储毗连和创立数据集。
·怎样处置和修正数据。
·怎样处置ADO毛病。
8.1ADO的界说
ADO是一个相称复杂的头脑,一种让你仅用一种体例往会见数据的头脑。ADO不算一个新头脑,仅是接纳现有的数据库会见手艺,并将其交融而构成的一种顺应如今和将来必要的新器材。顺应将来的需求是一件非常主要的事。很多其他的手艺,好比DAO和ODBC,在一些使用程序的开辟过程当中是能够承受的,但是跟着Internet的衰亡也呈现了其本身的一些成绩。
在很多情形下,传统的数据存取办法看上往能办理一些关于两层客户/服务器体系的成绩,但请求与数据之间要坚持一种永世性的毗连,并要供应壮大的功效,好比疾速呼应的查询、数据简单修正等。在Internet范畴,如今必需思索到Web无形态性实质,和潜伏的浩瀚能够会见Web站点的用户。要与数据创建永世的毗连是不实际的,因而必需在计划使用程序时思索这些要素。
那末,OLDDB和ADO切实地讲究竟是甚么?让我们与一些已有的数据存取手艺做对照后再往返答这个成绩。假如读者已经打仗过数据库编程,也许对照熟习ODBC和RDO。开放数据库毗连(ODBC)是同意会见干系数据库(好比Access和SQLServer)的使用程序编程接口(API)。正由于是一个API,很多程序员,出格是VisualBasic范畴的程序员,发明它利用起来很庞大。远程数据工具(RDO)是位于ODBC下层的ActiveX工具,能够供应ODBC的一切功效,而且利用起来对照复杂。
能够将OLEDB同等于ODBC,ADO同等于RDO。
OLEDB是使用程序与数据源交互的一种基础手艺。
这相称庞大,的确也只要C和C++程序员可以利用。正如ADO的名字所表示的,它是易于会见OLEDB功效的ActiveX工具。
你也许发明术语ActiveX与COM工具常常混用。关于ASP程序员来讲它们并没有实质上的区分,由于二者都基于COM体系布局,只不外ActiveX是组件的一个跨平台尺度,而COM是Windows专有的。
固然微软已引进了一种新的存取数据的手艺,但并没有当即作废旧的手艺,ODBC事情起来仍旧很无效,并同OLEDB和ADO严密地一同事情着。现实上,ODBC其实不只是微软的产物,也遭到国际组件的把持。而且因为普遍的利用,ODBC也不会俄然灭亡。埋没在OLEDB面前的头脑不是摒弃现有的手艺,而是不休地改善它们。
8.1.1OLEDB和ADO的系统布局
后面已给出了OLEDB与ADO在一些次要方面的扼要注释。-1显现了这两项手艺与使用程序和数据存储互相干系:
从-1中能够看出全体思绪。图的顶端是使用程序(Web或惯例的使用程序,这是可有可无的),上面是供应对数据的会见的ADO和/或OLEDB。ADO和OLEDB二者兼有是由于OLEDB是一项基础手艺。但是,OLEDB其实不合用于一切言语,以是ADO位于OLEDB的下层,为那些不克不及间接会见OLEDB的言语(如VisualBasic和剧本言语)供应编程接口。ADO供应了比OLEDB更简单的编程接口,因而即便那些能够间接利用OLEDB的编程言语,如C++或Java,也可以使用ADO以简化对数据的会见。
-1显现的是微软的编程言语,而ADO是一个COM组件,因而可用于任何与COM兼容的编程言语,好比Delphi或撑持ActiveScripting接口的剧本言语。以是,固然ADO与平台有关,但与开辟的言语是有关的。固然,关于ASP次要利用VBScript和JScript,在组件中利用ADO时,有一些VisualBasic代码。
如今晓得了OLEDB和ADO同意会见数据,但是为何必要它们?老办法出成绩了吗?这里有两个次要缘故原由:
起首,OLEDB和ADO是用来会见数据存储的。注重这里指“数据存储”而不是“数据库”。只管数据库仍然是数据存储最为普遍的情势,但其实不必定含有全体的数据。一些动静体系,如MicrosoftExchangeServer,也广泛地用于存储数据。目次服务(DirectoryService)正入手下手在初露眉目,它们包括着有关用户、呆板等的数据;Web服务器中存有大批的信息。能够持续排列下往,很分明必要一种能会见一切这些分歧范例数据的办法。
其次,源于Internet使用程序的衰亡与Web的形态实质。已往的会见数据的办法次要思索与数据存储坚持永世毗连的情形下处置数据。而OLEDB和ADO恰是为办理这个成绩而计划的,供应断开毗连的纪录集,我们将会在前面看到有关这方面的内容。
8.1.2消耗者与供应者
ADO体系布局图展现了ADO是怎样在使用程序和实在数据存储之间发扬感化的。在微软的文献中,会看到两个易懂的术语:消耗者(Consumer)和供应者(Provider),但弄清它们切实其实切界说相当主要。
供应者是供应数据的物体,消耗者是利用(损耗)这些数据的物体。
在编程中,常常会发明使用程序是数据的消耗者。但供应者呢?通常为数据存储,而且因为OLEDB被计划成用于与分歧的数据存储对话,因而关于每个共同范例的数据存储都有一个OLEDB供应者。
这类独自供应者的头脑其实不新,但使编程变得简单了。编写程序与ADO或OLEDB对话,OLEDB再与供应者对话。这意味着只需学会一套会见数据的办法,不管数据怎样存储,在某些情形下的确能够完整不改动任何代码而只改换供应者。这就是ADO和OLEDB真正优胜的中央,为数据存储供应了一套经常使用的编程接口。
要毗连到数据存储,必需利用OLEDB供应者。供应给ADO2.5的初始设置为:
·JetOLEDB4.0:用于微软Access数据库。
·DTSPackages:用于SQLServer的数据转换服务(DataTransformationServices)。
·InternetPublishing:用于会见Web服务器。
·IndexingServices:用于索引目次(IndexCatalogs)。
·SiteServerSearch:用于站点服务器查找目次。
·ODBCDrivers:用于ODBC数据源。
·OLAPServices:用于微软OLAP服务器。
·Oracle:用于Oracle数据库。
·SQLServer:用于微软SQLServer数据库。
·SimpleProvider:用于复杂的文本文件。
·MSDataShape:用于条理数据。
·MicrosoftDirectoryServices:用于Windows2000的目次服务。
·DTSFlatFile:用于SQLServer的数据转换服务的立体文件办理。
这只是微软供应的初始列表,并取决于安装在服务器上的服务及软件。以Oracle数据供应者为例,请求在客户机上安装Oracle的客户端软件。
能够从其余打造商那边取得OLEDB供应者,用于其他数据存储。乃至还能够编写本人的供应者。在第11章,将演示怎样编写复杂的OLEDB供应者。
要想晓得体系安装了哪些供应者,可使用DataLinkproperties对话框。在本章前面,将先容怎样利用它。
8.1.3供应者和驱动程序
值得注重的是,OLEDB对ODBC的兼容性,同意OLEDB会见现有的ODBC数据源。其长处很分明,因为ODBC绝对OLEDB来讲利用得更加广泛,因而能够取得的ODBC驱动程序响应地要比OLEDB的要多。如许纷歧定要失掉OLEDB的驱动程序,就能够当即会见原本的数据体系。
制止搅浑供应者与驱动程序是主要的,-2明白了它们之间的区分:
供应者位于OLEDB层,而驱动程序位于ODBC层。假如想利用一个ODBC数据源,必要利用针对ODBC的OLEDB供应者,它会接着利用响应的ODBC驱动程序。假如不必要利用ODBC数据源,那末可使用响应的OLEDB供应者,这些一般称为当地供应者(nativeprovider)。
能够分明地看出利用ODBC供应者意味着必要一个分外的层。因而,当会见不异的数据时,针对ODBC的OLEDB供应者大概会比当地的OLEDB供应者的速率慢一些。
Windows本身的所有问题都会一成不变的也累加到了它的身上。安全性、稳定性、跨平台性都会因为与NT的捆绑而显现出来; 我认为比较好的方法是找一些比较经典的例子,每个例子比较集中一种编程思想而设计的。 ASP也是这几种脚本语言中最简单易学的开发语言。但ASP也是这几种语言中唯一的一个不能很好支持跨平台的语言。 因为ASP脚本语言非常简单,因此其代码也简单易懂,结合HTML代码,可快速地完成网站的应用程序。 哪些内置对象是可以跳过的,或者哪些属性和方法是用不到的? 我可以结合自己的经验大致给你说一说,希望对你有所帮助,少走些弯路。 跟学别的语言一样,先掌握变量,流程控制语句(就是ifwhileselect)等,函数/过程,数组 以HTML语言整合(HTML负责界面上,ASP则负责功能上)形成一个B/S(浏览器/服务器)模式的网页程序。 ASP的语言不仅仅只是命令格式差不多,而是包含在<%%>之内的命令完全就是VB语法。虽然ASP也是做为单独的一个技术来提出的,但他就是完全继承了VB所有的功能。
页:
[1]