zoukankan      html  css  js  c++  java
  • My dbconn of ASP

    <%Set myconn = Server.CreateObject("ADODB.Connection")
    myconn.open "driver=microsoft access driver (*.mdb);pwd=sa; dbq="&server.mappath("datafiles/db1.mdb")
    myconn.open "driver={sql server};server=mint;uid=sa;pwd=;database=tjzz;" 

    %>

    一、存取数据库的原理

    在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的作用是打开数据表。

    Function CreateMdbRecordset(数据库文件名, 数据表名或Select语句 )
    Dim conn,Provider,DBPath
    ’建立Connection 对象
    Set conn = Server.CreateObject(“ADODB.Connection”)
    Provider=“Provider=Microsoft.Jet.OLEDB.4.0;”
    DBPath = “Data Source=” & Server.MapPath(“数据库文件名”)
    ’打开数据库
    conn.Open Provider & DBPath
    Set CreateMdbRecordset = Server.CreateObject(“ADODB.Recordset”)
    ’打开数据表
    CreateMdbRecordset.Open “数据表名”, conn, 2, 2
    End Function

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

    Function CreateSecuredMdbRecordset( 数据库文件名, 数据表名或Select语句,password )
    Dim conn,Provider,DBPath
    ’建立Connection 对象
    Set conn = Server.CreateObject(“ADODB.Connection”)
    Provider = “Provider=Microsof.Jet.OLEDB.4.0;”
    DBPath = “Data Source=”& Server.MapPath(“数据库文件名”)
    ’连接数据库,注意要带有密码参数
    conn.Open Provider & DBPath&“Jet OLEDB:Database Password=”&assword
    Set CreateSecuredMdbRecordset = Server.
    CreateObject(“ADODB.Recordset”)
    ’打开数据表
    CreateSecuredMdbRecordset.Open “数据表名”, conn, 2, 2
    End Function

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

    Function CreateDbfRecordset( 目录名, DBF文件名或Select语句 )
    Dim conn,Driver,SourceType,DBPath
    ’建立Connection 对象
    Set conn = Server.CreateObject(“ADODB.Connection”)
    Driver=“Driver={Microsoft Visual FoxProDriver};” SourceType = “SourceType=DBF;”
    DBPath=“SourceDB=” & Server.MapPath(“目录名”)
    ’调用Open 方法打开数据库
    conn.Open Driver & SourceType & DBPath
    Set CreateDbfRecordset = Server.CreateObject(“ADODB.Recordset”)
    ’打开DBF文件
    CreateDbfRecordset.Open “DBF文件名或Select语句”, conn, 2, 2
    End Function

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

    Function CreateDbcRecordset( DBC数据库文件名, 数据表名或Select语句 )
    Dim conn,Driver,SourceType,DBPath
    ’建立Connection 对象
    Set conn = Server.CreateObject(“ADODB.Connection”)
    Driver=“Driver={Microsoft Visual FoxPro Driver};”
    SourceType = “SourceType=DBC;”
    DBPath = “SourceDB=” & Server.MapPath(“DBC数据库文件名”)
    ’连接数据库
    conn.Open Driver & SourceType & DBPath
    Set CreateDbcRecordset = Server.CreateObject(“ADODB.Recordset”)
    ’打开数据表
    CreateDbcRecordset.Open“数据表名或Select语句”, conn, 2, 2
    End Function

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

    Function CreateExcelRecordset(XLS文件名,Sheet名)
    Dim conn.Driver,DBPath
    ’建立Connection对象
    Set conn = Server.CreateObject(“ADODB.Connection”)
    Driver=“Driver={Microsoft Excel Driver (*.xls)};”
    DBPath = “DBQ=” & Server.MapPath(“XLS文件名”)
    ’调用Open 方法打开数据库
    conn.Open Driver & DBPath
    Set CreateExcelRecordset = Server.CreateObject(“ADODB.Recordset”)
    ’打开Sheet
    CreateExcelRecordset.Open “Select * From [”&sheet&“$]”, conn, 2, 2
    End Function

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

    Function CreateSQLServerRecordset(计算机名称,用户ID, 用户密码,数据库名称 数据表或查看表或Select指令 )
    Dim Params, conn
    Set CreatSQLServerConnection = Nothing
    Set conn = Server.CreateObject (“ADODB.Connection”)
    Params = “Provider=SQLOLEDB.1”
    Params = Params & “;Data Source=” & Computer
    Params = Params & “;User ID=” & UserID
    Params = Params & “;Password=” & Password
    Params = Params & “.Initial Catalog=”&数据库名称
    Conn open Paras
    Set CreateSQLServerRecordset = Server. CreateObject(“ADODB.Recordset")
    CreateSQLServerRecordset.Open source, conn, 2, 2
    End Function

  • 相关阅读:
    算法笔记_182:历届试题 核桃的数量(Java)
    算法笔记_181:历届试题 回文数字(Java)
    算法笔记_180:历届试题 国王的烦恼(Java)
    算法笔记_179:历届试题 数字游戏(Java)
    算法笔记_178:历届试题 邮局(Java)
    算法笔记_177:历届试题 城市建设(Java)
    算法笔记_176:历届试题 最大子阵(Java)
    算法笔记_175:历届试题 蚂蚁感冒(Java)
    redis集群与分片(2)-Redis Cluster集群的搭建与实践
    redis集群与分片(1)-redis服务器集群、客户端分片
  • 原文地址:https://www.cnblogs.com/Mint/p/245643.html
Copyright © 2011-2022 走看看