分享

ASP 连接字符串 .

 aaie_ 2012-09-11

一、存取数据库的原理

在ASP中,用来存取数据库的对象统称ADO对象(Active Data Objects),主要含有三种对象:Connection、Recordset和Command,其中Connection负责打开或连接数据库,Recordset负责存取数据表,Command负责对数据库执行行动查询(Action Query)命令和执行SQL Server的Stored Procedure。只依靠这三个对象还是无法存取数据库的,还必须具有数据库存取的驱动程序:OLE DB驱动程序和ODBC驱动程序。对于任何一种数据库都必须有相对应的OLE DB驱动程序和ODBC驱动程序,ADO对象才能对数据库进行存取。

ADO对象必须与各种驱动程序相结合才能存取各种类型数据库,不同的数据库需要不同的驱动程序。在Windows 9x/NT的"开始"→"设置"→"控制面板" →"ODBC Data Source(32Bit)"中的"驱动程序"标签页,可以查证机器上究竟装了哪些驱动程序。

二、连接数据库和打开数据表

不同数据库的连接方法有所不同(即建立Connection实例的方法不一样),但建立Connection实例后,利用Recordset对象进行存取数据的方法却大同小异。下面对于不同的数据类型,编写了相对应的连接函数,在程序中直接引用即可。

程序用VB Script脚本语言编写。

1.建立MdbRecordset对象。MDB数据库是一个完整的数据库,内部可能含有若干个数据表,在此函数中,Connection的作用是连接数据库,Recordset的作用是打开数据表。

  1. Function CreateMdbRecordset(数据库文件名, 数据表名或Select语句 )  
  2.   Dim conn,Provider,DBPath  
  3.   '建立Connection 对象  
  4.   Set conn = Server.CreateObject("ADODB.Connection")  
  5.   Provider="Provider=Microsoft.Jet.OLEDB.4.0;"  
  6.   DBPath = "Data Source=" & Server.MapPath("数据库文件名")  
  7.   '打开数据库  
  8.   conn.Open Provider & DBPath  
  9.   Set CreateMdbRecordset = Server.CreateObject("ADODB.Recordset")  
  10.   '打开数据表  
  11.   CreateMdbRecordset.Open "数据表名", conn, 2, 2  
  12. End Function   

 

2.建立带密码的MDB数据库的Recordset对象。它的建立方式与建立不带密码的MDB数据库的Recordset对象类似,只是多了一个密码参数,即在与数据库连接时,必须给出密码信息。

  1. Function CreateSecuredMdbRecordset( 数据库文件名, 数据表名或Select语句,password )  
  2.  Dim conn,Provider,DBPath  
  3.  '建立Connection 对象  
  4.  Set conn = Server.CreateObject("ADODB.Connection")  
  5.  Provider = "Provider=Microsof.Jet.OLEDB.4.0;"  
  6.  DBPath = "Data Source="& Server.MapPath("数据库文件名")  
  7.  '连接数据库,注意要带有密码参数  
  8.  conn.Open Provider & DBPath&"Jet OLEDB:Database Password="&assword  
  9.  Set CreateSecuredMdbRecordset = Server.  
  10.  CreateObject("ADODB.Recordset")  
  11.  '打开数据表  
  12.  CreateSecuredMdbRecordset.Open "数据表名", conn, 2, 2  
  13. End Function   

 

3.DBF文件不是一个标准的数据库文件,只相当于标准数据库文件中的一个数据表,所以为了使用DBF文件,可以把所有的DBF文件放在一个目录下,这样把目录名看成标准数据库,每一个DBF文件相当于标准数据库中的数据表。下面函数中的Directory是DBF所在的目录名。

 

  1. Function CreateDbfRecordset( 目录名, DBF文件名或Select语句 )  
  2.  Dim conn,Driver,SourceType,DBPath  
  3.  '建立Connection 对象  
  4.  Set conn = Server.CreateObject("ADODB.Connection")  
  5.  Driver="Driver={Microsoft Visual FoxProDriver};" SourceType = "SourceType=DBF;"  
  6.  DBPath="SourceDB=" & Server.MapPath("目录名")  
  7.  '调用Open 方法打开数据库  
  8.  conn.Open Driver & SourceType & DBPath  
  9.  Set CreateDbfRecordset = Server.CreateObject("ADODB.Recordset")  
  10.  '打开DBF文件  
  11.  CreateDbfRecordset.Open "DBF文件名或Select语句", conn, 2, 2  
  12. End Function   

 

4.由FoxPro生成的DBC数据库与MDB数据库相似,都是一个数据库包含几个数据表的形式,所以对DBC数据库的存取方法与MDB数据库相似。

  1. Function CreateDbcRecordset( DBC数据库文件名, 数据表名或Select语句 )  
  2.  Dim conn,Driver,SourceType,DBPath  
  3.  '建立Connection 对象  
  4.  Set conn = Server.CreateObject("ADODB.Connection")  
  5.  Driver="Driver={Microsoft Visual FoxPro Driver};"  
  6.  SourceType = "SourceType=DBC;"  
  7.  DBPath = "SourceDB=" & Server.MapPath("DBC数据库文件名")  
  8.  '连接数据库  
  9.  conn.Open Driver & SourceType & DBPath  
  10.  Set CreateDbcRecordset = Server.CreateObject("ADODB.Recordset")  
  11.  '打开数据表  
  12.  CreateDbcRecordset.Open"数据表名或Select语句", conn, 2, 2  
  13. End Function  

 

5.将Excel生成的XLS文件(book)看成一个数据库,其中的每一个工作表(sheet)看成一个数据库表。

  1. Function CreateExcelRecordset(XLS文件名,Sheet名)  
  2.  Dim conn.Driver,DBPath  
  3.  '建立Connection对象  
  4.  Set conn = Server.CreateObject("ADODB.Connection")  
  5.  Driver="Driver={Microsoft Excel Driver (*.xls)};"  
  6.  DBPath = "DBQ=" & Server.MapPath("XLS文件名")  
  7.  '调用Open 方法打开数据库  
  8.  conn.Open Driver & DBPath  
  9.  Set CreateExcelRecordset = Server.CreateObject("ADODB.Recordset")  
  10.  '打开Sheet  
  11.  CreateExcelRecordset.Open "Select * From ["&sheet&"$]", conn, 2, 2  
  12. End Function   

 

6.SQL Server属于Server级的数据库,使用时要求比较严格,必须要输入用户名及密码才能使用。

 

  1. Function CreateSQLServerRecordset(计算机名称,用户ID, 用户密码,数据库名称 数据表或查看表或Select指令 )  
  2.  Dim Params, conn  
  3.  Set CreatSQLServerConnection = Nothing  
  4.  Set conn = Server.CreateObject ("ADODB.Connection")  
  5.  Params = "Provider=SQLOLEDB.1"  
  6.  Params = Params & ";Data Source=" & Computer  
  7.  Params = Params & ";User ID=" & UserID  
  8.  Params = Params & ";Password=" & Password  
  9.  Params = Params & ".Initial Catalog="&数据库名称  
  10.  Conn open Paras  
  11.  Set CreateSQLServerRecordset = Server. CreateObject("ADODB.Recordset")  
  12.  CreateSQLServerRecordset.Open source, conn, 2, 2  
  13. End Function  
  14. Dim conn,Driver,SourceType,DBPath  
  15.   ' 建立Connection 对象  
  16.   Set conn = Server.CreateObject("ADODB.Connection")  
  17.   Driver = "Driver={ Microsoft Visual FoxPro Driver};"  
  18.   SourceType = "SourceType=DBF;"  
  19.   DBPath = "SourceDB=" & Server.MapPath( "目录名" )  
  20.   ' 调用Open 方法打开数据库  
  21.   conn.Open Driver & SourceType & DBPath  
  22.   Set CreateDbfRecordset = Server.CreateObject("ADODB.Recordset")  
  23.   ' 打开DBF文件,参数二为Connection对象  
  24.   CreateDbfRecordset.Open DBF文件名或Select语句, conn, 2, 2   

 

asp连接数据库字符串:

  1. Set conn = Server.CreateObject("ADODB.Connection")  
  2. connstr = "Driver={SQL Server};Server=localhost(数据库所在的位置),1433;NETWORK=DBMSSOCN;UID=wap(连接数据库的用户名);PWD=wap(连接数据库的密码);DATABASE=wap(连接数据库的库名);"  
  3. conn.Open connstr   

 

  1. <%  
  2. dim conn,rs  
  3. set conn=server.createobject("adodb.connection")  
  4. DBpath=Server.Mappath("../data/bbs.mdb")  
  5. Conn.Open "driver={Microsoft Acess Driver(*.mdb)};dbq="&Dbpath  
  6. s="select * from friend"  
  7. Set rs=Server.CreatObject("ADODB.Recordset")  
  8. rs.open s,conn,3  
  9. %>  

 


原理:
在实际应用开发中,特别是在WEB应用系统中,如果JSP、Servlet或EJB使用JDBC直接访问数据库中的数据,每一次数据访问请求都必须经历建立数据库连接、打开数据库、存取数据和关闭数据库连接等步骤,而连接并打开数据库是一件既消耗资源又费时的工作,如果频繁发生这种数据库操作,系统的性能必然会急剧下降,甚至会导致系统崩溃。数据库连接池技术是解决这个问题最常用的方法,在许多应用程序服务器(例如:Weblogic,WebSphere,JBoss)中,基本都提供了这项技术,无需自己编程,但是,深入了解这项技术是非常必要的。
数据库连接池技术的思想非常简单,将数据库连接作为对象存储在一个Vector对象中,一旦数据库连接建立后,不同的数据库访问请求就可以共享这些连接,这样,通过复用这些已经建立的数据库连接,可以克服上述缺点,极大地节省系统资源和时间。
数据库连接池的主要操作如下:
(1)建立数据库连接池对象
(2)按照事先指定的参数创建初始数量的数据库库连接
(3)对于一个数据库访问请求,直接从连接池中得到一个连接。如果数据库连接池对象中没有空闲的连接,且连接数没有达到最大,创建一个新的数据库连接。
(4)存取数据库。
(5)关闭数据库,释放所有数据库连接。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多