连接Access数据库常用方法有哪些

连接Access数据库常用方法有哪些,第1张

在基于微软IIS/PWS的网络平台上,通过服务器端运行的ASP程序来访问后台数据,是一种最常见的模式了。而对于小型的数据库应用需求,微软的Access数据库,应该是与ASP程序配套使用的首选。由于Access数据库的ODBC驱动程序支持的SQL指令全,执行效率高,所以Access后台数据库+ASP服务器端程序+客户端IE浏览器,是一个精练实用高效的组合模式。

在这种使用模式中,ASP程序无疑是最重要的,是沟通客户端和后台数据库之间的桥梁。在ASP程序中,通过VB Script,建立对Access数据库的连接,是客户能够访问后台数据库的前提。

一、建立Access数据库连接的常用方法

在ASP中建立对Access数据库连接的一般格式如下:

<%

DbPath=ServerMapPath(数据库名)

Set Conn=ServerCreatObject(“ADODBConnection”)

ConnOpen “driver={Microsoft Access Driver (mdb)};dbq=”& DbPath

Set rs=ServerCreatObject(“ADODBRecordset”)

RsOpen 数据表名或SQL指令,Connection对象,Recordset类型,锁定类型

… …

%>

它的各步骤及参数意义如下:

第一行程序:利用Server对象的MapPath函数,取得要打开数据库的完整的文件路径,并存储在变量DbPath中。这其中,数据库名是我们需要指定的参数,应该用我们要打开的数据库的实际名称替代。如果数据库名是直接作为常量出现,要用引号将其括起来,并且不能丢掉扩展名。例如数据库是Testmdb,则该行程序成为:DbPath=ServerMapPath(“Testmdb”)。

第二行程序:建立一个ADO对象集中的Connection对象,也即连接对象。这是建立数据库连接的初始步骤。执行这行程序后,Conn成为一个连接对象。

第三行程序:利用连接对象Conn的Open方法打开一个指定的数据库。因为我们要打开的是Access数据库,所以要指定ODBC驱动程序参数,表示要透过Access的ODBC驱动程序来访问数据库:driver={Microsoft Access Driver (mdb)};。另一个参数dbq= & DbPath,运算后等效于dbq=ServerMapPath(数据库名) ,是利用了第一行的ServerMapPath(数据库名)函数,用来指定要打开的数据库文件。到这里,就已经打开了数据库名指定的数据库。如果数据库名是“testmdb”,则打开Access数据库Testmdb。在这一行里指定的参数,要严格按照格式原样写出,不能省略或改动,也没有可变参数。

第四行程序:建立一个ADO对象集中的Recordset对象,以便利用Recordset对象 *** 作数据库(当然,这只是对数据库 *** 作的多种方式之一)。执行这行后,rs就成为一个Recordset对象。

第五行程序:利用rs对象的Open方法打开数据库中的数据表。这其中有四个参数,其意义如下:

数据表名或SQL指令串:在这个参数里指定要打开的数据库内的数据表名称,或者是用SQL的Select指令串确定的数据表的指定范围数据,例如,数据库Testmdb中有数据表Number,则该参数成为“Number”,注意引号不能丢;若想打开数据表Number中xh字段值小于90的数据记录,则该参数可能成为如下的形式:

“Select From Number Where xh < 90”。

Connection对象:指定已经打开的数据库的Connection对象,在这里固定是Conn,注意无须引号的。

Recordset类型:表示打开数据表的方式,有四种选择。数字0表示只读方式,且当前记录只能下移;数字1表示可读写方式,当前记录可自由上下移动,但不能及时看到别的用户建立的新记录,除非重新启动;数字2表示可读写方式,当前记录可自由移动,而且可以及时看到别的用户增加的新记录;数字3表示只读方式,但当前记录可以自由移动。一般选择2为好,除非为了禁止数据被修改。

锁定类型:这个参数指定数据库的锁定功能。因为网络上的数据库都是多用户的,很可能同时有多个用户在 *** 作数据库。为了避免错误,让同一时间只可能有一个用户修改数据,就要用锁定功能。有四种选择:数字1表示只读方式锁定,用户不能更改数据;数字2表示悲观锁定,当一个用户用rs对象开始修改数据时就锁定数据库,直到用户用rsUpdate更新记录后,才解除锁定;数字3表示乐观锁定,只有在数据写入数据库中时候才锁定,不保险,慎用!数字4表示批次乐观锁定,只有在使用rsUpdateBatch成批更新数据时候才锁定数据记录。属于很少使用的。一般地,使用悲观锁定比较安全,但是效率要低些。

二、使用Recordset对象 *** 作数据

用上面的方法打开数据库,是利用了Recordset对象建立的数据库连接,然后的对数据 *** 作,也要使用该对象。

用rsopen “数据表名”,Conn,2,2 方式打开数据表,就可以方便的对数据进行 *** 作:

常见的 *** 作对象:

rsaddnew :添加一个新记录在数据表末尾。

rsdelete :删除当前记录。

rseof :判断是否已过最后记录。

rsbof :判断是否移过首记录。

rsupdate :数据修改生效。

rs(“字段名”):当前记录指定字段的值。

从数据表中提取数据:用x=rs(“字段名”)的格式,提取数据表中当前记录指定字段的值。

向数据表中填入或修改数据:用rs(“字段名”)=数据值或变量的方式,修改当前记录指定字段的值。

三、使用SQL指令 *** 作数据库

在使用SQL指令对数据库进行 *** 作时,要用如下方式打开数据库和 *** 作:

<%

DbPath=ServerMapPath(数据库名)

Set Conn=ServerCreatObject(“ADODBConnection”)

ConnOpen “driver={Microsoft Access Driver (mdb)};dbq=”& DbPath

Sql= *** 作数据库的指令串

ConnExecute sql

… …

%>

四、使用DSN连接数据库

在以上连接数据库的方式中,都是在程序中指定数据库,指定ODBC驱动程序。如果数据源有变化,就需要修改程序。如果在系统级别上,预先定义好数据源DSN,就可以避免这个麻烦。

在定义DSN的过程中,就已经指定好了数据源需要的ODBC驱动程序,也指定好了数据库文件的实际路径和名字,我们在程序中,只需要引用预先定义的数据源名DSN即可。

设定义好的DSN为test,则打开数据库的方式为:

五、结束语

在ASP程序中,建立数据库的连接和访问数据库,有很多方式和技术细节,在此难以一一详述。实际上,对SQL Server数据库,DBF数据库,文本文件,电子表格文件等,也都可以很方便的打开和访问,与对Access数据库的访问大同小异而已。如果说方便,Access应该是首选。如果考虑安全保密性,SQL数据库更好些。使用系统数据源DSN的方式建立对数据库的连接,具有更大的灵活性,也更简便些。

你说的就是最简单的用户登陆了,很简单的

HTML结构如下:

<form action="login_doasp" type="post">

    用户名:<input type="text" name="username">

    密码:<input type="password" name="pwd">

    <button type="submit">登陆</button>

</form>

用户登陆的前台界面就是上面这段核心代码了,你可以在这个基础上进行美化和加工,下面来看login_doasp,也就是处理判断数据的ASP页面的核心 代码 :

<%

Dim username,pwd

username=requestform("username")

pwd=requestform("pwd")

'上面这是获取到表单里用户输入的数据

'下面开始连接数据库

set MdbConn=serverCreateObject("ADODBconnection")

MdbConnopen "Provider=MicrosoftJetOLEDB40; Data Source="&serverMapPath(数据库路径)

set MdbCmd=serverCreateObject("Adodbcommand")

MdbCmdactiveconnection=MdbConn

set MdbRs=serverCreateObject("Adodbrecordset")

'数据库连接成功后,开始检索数据库,判断用户输入的用户名和密码

MdbCmdcommandtype=1

MdbCmdcommandtext="select id from 表名 where 字段1='"&username&"' and 字段2='"&pwd&"'"

MdbRsopen MdbCmd

if MdbRseof and MdbRsbof then

    //用户名或密码错误

    //可以用 ResponseRedirect "Loginhtml"来返回登陆面

else

    //有数据就表示正确

    //输入正面,就可以在这里生成COOKIE,然后在其它页面判断的时候 就可以通过cookie来判断用户是否登陆

    ResponseCookies"UName")=username

    //用ResponseRedirect "管理页" 来转到管理页

end if

’关闭数据库连接

MdbRsclose

set MdbRs=nothing

set MdbCmd=nothing

MdbConnclose

set MdbConn=nothing

%>

代码虽然看起来复杂,但都是最基础的东西,希望能帮助到你!

using SystemData;

using SystemDataOleDb;

private OleDbConnection con;

/// <summary>

/// 打开数据库连接

/// </summary>

/// <param name="DBpath">数据库路径(包括数据库名)</param>

private void Open(String DBpath)

{

if(con == null)

con = new OleDbConnection("Provider=MicrosoftJetOLEDB40;Data Source=" + DBpath);

if (conState == ConnectionStateClosed)

conOpen();

}

/// <summary>

/// 创建一个命令对象并返回该对象

/// </summary>

/// <param name="sqlStr">数据库语句</param>

/// <param name="file">数据库所在路径</param>

/// <returns>OleDbCommand</returns>

private OleDbCommand CreateCommand(string sqlStr, string file)

{

Open(file);

OleDbCommand cmd = new OleDbCommand();

cmdCommandType = CommandTypeText;

cmdCommandText = sqlStr;

cmdConnection = con;

return cmd;

}

/// <summary>

/// 执行

/// </summary>

/// <param name="sqlStr">SQL语句</param>

/// <param name="file">数据库所在路径</param>

/// <returns>返回数值当执行成功时候返回true,失败则返回false</returns>

public bool ExecuteNonQury(string sqlStr, string file)

{

OleDbCommand cmd = CreateCommand(sqlStr, file);

int result = cmdExecuteNonQuery();

if (result == -1 | result == 0)

{

cmdDispose();

Close();

return false;

}

else

{

cmdDispose();

Close();

return true;

}

/// <summary>

/// 执行数据库查询

/// </summary>

/// <param name="sqlStr">查询语句</param>

/// <param name="tableName">填充数据集表格的名称</param>

/// <param name="file">数据库所在路径</param>

/// <returns>查询的数据集</returns>

public DataSet GetDataSet(string sqlStr, string file)

{

DataSet ds = new DataSet();

OleDbCommand cmd = CreateCommand(sqlStr, file);

OleDbDataAdapter dataAdapter = new OleDbDataAdapter(cmd);

dataAdapterFill(ds);

cmdDispose();

Close();

dataAdapterDispose();

return ds;

}

/// <summary>

/// 生成一个数据读取器OleDbDataReader并返回该OleDbDataReader

/// </summary>

/// <param name="sqlStr">数据库查询语句</param>

/// <returns>返回一个DataReader对象</returns>

public OleDbDataReader GetReader(string sqlStr, string file)

{

OleDbCommand cmd = CreateCommand(sqlStr, file);

OleDbDataReader reader = cmdExecuteReader(CommandBehaviorCloseConnection);

//CommadnBehaviorCloseConnection是将于DataReader的数据库链接关联起来

//当关闭DataReader对象时候也自动关闭链接

return reader;

}

/// <summary>

/// 关闭数据库

/// </summary>

public void Close()

{

if (con != null)

conClose();

con = null;

}

传进来的路径是带上Access数据库名的

您好,我是玵羽薇 。希望能帮到您。其实就是ASP与数据库的连接,在数据库中读取、添加、删除数据。 1与Access数据库建立连接: 其中"&ServerMapPath("Namemdb")为数据库绝对路径,&ServerMapPath()即返回当前服务器的绝对地址,Namemdb就是数据库的名称。 到这里,我们已经建立的与数据库的连接了,意思说,我们已经取得了与数据库的联系,下一步,我们就用指令来—— 2从数据库中读取数据记录: 其中rs("Lable")便是代表当前记录的Lable字段值,也就是当前记录的编号。 这样可以遍历数据库输出: 关闭数据库以释放内存: 3写入数据库: 其中Insert Into Name(Lable1,Lable2,) Values("&Data1&","&Data2&",)就是将记录Data1、Data2等插入到Lable1、Lable2等字段中。 以上内容参考了: >

Set conn = ServerCreateObject("ADODBConnection")

DBPath = ServerMapPath("数据库名mdb")

connOpen "driver={Microsoft Access Driver (mdb)};dbq=" & DBPath

或是用连接文件

站点建了,DW也管理了,数据库表也建了,还小添了一下。那下面就开用DW还算强大的功能:连接数据库并且显示纪录。

1,打开DW,在站点里面先新建个ASP页面(indexasp)。 在“应用程序”面板中选中“数据库”标签。只要我们在前面建立了站点,选择了文档类型(即我们选的ASP Javascript的),并且还测试了服务器(>

以上就是关于连接Access数据库常用方法有哪些全部的内容,包括:连接Access数据库常用方法有哪些、asp怎么让登录页面与access数据库链接,实现登陆并跳转到另外一个页面,如输入不正确,则不登录、access数据库怎么连接网页的留言板等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9744805.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存