日期:2012-03-11  浏览次数:20804 次


    如果需要访问一个数据存储,应该创建一个到数据存储的连接。前面已经提到过:可以显式地创建一个Connection对象,或者让ADO隐含地创建一个连接。对于任何一种方式,都必须知道数据存储的详细内容。
       虽然用于连接的实际细节不尽相同,但对于所有类型的数据存储,其连接的实际方法是相同的。这并不令人惊奇,因为不同的提供者需要不同类型的信息。在允许用户访问数据存储之前,一些提供者需要用户的证书,而别的提供者却接受默认的安全证书。
       连接到数据源有好几种方法:
       · 连接字符串。在字符串中放入连接的细节,或在打开数据存储时,直接将连接细节加入到命令中。这种方法的优点是连接细节将保留在ASP页面中。不足之处,如果你有较多的页面,在改变了连接细节时,将陷于繁重的维护工作当中。解决的方法是创建一个包含连接细节的字符串变量,并放进一个ASP包含文件,这样的话仅仅有一个连接字符串的实例,但能保持与其他的ASP页面相符。另一个常用的技术就是将应用程序中的连接字符串存储到状态变量中,这样可以被应用程序中的所有页面使用。
       · 数据链接文件。这是一个含有连接细节的文件(扩展名为.udl)。优点是对于任何数据的ASP页面只需要一个数据链接文件。要创建一个数据链接文件,只需创建一个新的文本文件,并重新命名(要确保Windows资源管理器显示文件扩展名)。一旦重新命名了该文件,就可以打开它(双击)以显示Data Link Properties对话框。以前版本的ADO允许从Windows资源管理器的New菜单建立数据链接文件。我们将在本章稍后看到有关数据链接文件的内容。
       · ODBC数据源,或DSN。有点类似于数据链接文件,但只适用于ODBC数据源。它们集中起来用于ASP页面,数据源必须是系统数据源。ODBC数据源从ODBC数据源管理器(ODBC Data Source Administrator)中创建,这个工具可在Administrative Tools文件夹中找到。
       这三种方式无论哪一种都可以使用,使用哪一种只是一种偏爱而已。直接的连接字符串可能速度快一些,因为提供所有的连接细节。数据链接文件需要从文件中读出连接细节,ODBC数据源需要从注册表中读取连接细节。当然,速度的差异是很小的,每种方法各有优缺点。

8.3.1 连接字符串
       连接字符串依赖于提供者,因为每个数据提供者可能需要不同的细节。
       值得注意的重要一点是,ODBC的OLE DB提供者是缺省的,所以,如果不使用Provide=部分,系统将自动地使用ODBC。
       下面为不同的提供者列举了连接字符串的例子,在本书的后面将会看到更多的例子。
1.  微软Access
如果使用ODBC,而没有DSN:
Driver={Microsoft Access Driver (*.mdb)}; DBQ=C:wroxdatabase_name.mdb
对于本地的OLE DB提供者:
Provider=Microsoft.Jet.OLEDB.4.0; Data Source=C:wroxdatabase_name.mdb
上面的例子说明了Access数据库存放于C:wrox目录下。虽然读者可能会尝试将数据库作为Web文件存放于相同的目录下,但不要这样做,否则任何人都可以下载整个数据库文件。将数据库存放于Web目录外永远是明智的,没有人可以从外面访问该文件。
2.  微软SQL Server
对于微软SQL Server,使用针对ODBC的提供者:
Driver={SQL Server}; Server=server_name; Database=database_name; UID=user_name;
PWD=user_password
例如:
Driver={SQL Server}; Server=WATCHER; Database=pubs; UID=davids; PWD=whisky
对于本地OLE DB提供者,语法类似:
Provider=SQLOLEDB; Data Source=server_name; Initial Catalog=database_name;
User Id=user_name; Password=user_password
例如:
Provider=SQLOLEDB; Data Source=WATHCHER; Initial Catalog=pubs; User Id=davids;
Password=whisky
3.  微软索引服务
索引服务只能通过本地的OLE DB提供者使用。其语法:
Provider=MSIDXS; Data Source=catalog_name
例如,使用Web目录
Provider=MSIDXS; Data Source=Web
4.  ODBC驱动程序
在使用针对ODBC的OLE DB提供者的例子中,Driver显得较为冗长。例如:
Driver={Microsoft Access Driver (*.mdb)}; DBQ=C:wroxdatabase_name.mdb
当创建一个新数据源时,使用的驱动程序的准确名字应该是从驱动程序列表中得到的,如图8-6所示:

5.  数据链接文件
以前版本的ADO允许在资源管理器中的目录上右击鼠标来创建一个数据链接文件。创建了新文件后,打开该文件从而得到Data Link Properties对话框。在写本书的时候,微软已经从鼠标右键菜单中删除了该选项,因为他们觉得这会让用户感到混乱。但微软声称会提供一个注册表文件以便再次引入这项功能。
不要忘了,也可以简单地通过创建一个空文本文件,并将其扩展名改为.udl来创建一个数据链接文件。
一旦有了物理上的数据链接文件,就可以通过鼠标双击或者右击鼠标选择Open打开文件。接下来,读者会看到图8-7所示的对话框:

图中的详细内容因选择的提供者的不同而不同。上面的例子显示了SQL Server提供者,连接到一个称为WATHER的SQL Server上,以davids的身份登录(口令被屏蔽了),使用pubs数据库。注意,如果选择Allow saving password选择,输入的口令将会在UDL文件中以明文保存下来。
如果要改变提供者,可以选择“Provider”(提供者)选项卡,如图8-8所示:

通过这个选择,可以选出所需的提供者,然后按下Next按钮填入适当的连接细节。
也可以在文本编辑器中编辑文件,如图8-9所示:

可以看到在UDL文