asp oracle网站源码下载,asp连接oracle

Oracle是世界上用得最多的数据库之一,活动服务器网页(ASP)是一种被广泛用于创建动态网页的功能强大的服务器端脚本语言。许多ASP开发人员一直在考虑,能否在开发互联网应用、电子商务网站、互联网管理系统时结合使用ASP和Oracle数据库?这个问题的答案是肯定的,我们还可以使用VB访问

Oracle数据库。在本篇文章中,我们将主要讨论如何使用ASP来处理Oracle数据库中数据的方法。

在开始讨论这个问题前,我们需要了解几个背景知识,Oracle Objects for OLE就是其中之一。Oracle Objects

for OLE是Oracle开发的一个中间件,它允许使用微软的OLE标准的客户端应用程序访问Oracle的数据库。也许会有读者说,我们也可以使用ODBC

访问Oracle的数据库。当然,可以使用ODBC访问Oracle数据库,但我认为,Oracle Objects for

OLE比ODBC更安全,而且完全支持PL/SQL。PL/SQL是Oracle对SQL命令集的扩展,开发人员能够利用它对非结构化的SQL命令块进行流控制和逻辑设计。如果安装的是Oracle8i数据库,我相信你已经在使用Oracle

Objects for OLE。如果还没有使用Oracle Objects for OLE,可以从Oracle的网站上下载它。

另外,我们还需要了解Oracle针对Visual

Basic开发的二个对象和一个接口:OraSession、OraDynaset对象和OraDatabase接口。OraSession对象管理应用程序的OraDatabase、OraConnection和OraDynaset,它是由ASP的CreateObject而不是Oracle

Objects for

OLE创建的一个对象。OraDatabase接口向Oracle数据库表示表现用户对话,并为SQL、PL/SQL的执行提供方法。它们每个都有一些属性和方法。例如,OraDynaset对象有BOF、EOF、Bookmark、Connection等属性以及AddNew、Update、

Delete、Edit、Refresh、Clone等10个方法。

下面我们就开始切入主题,讨论如何使用ASP处理Oracle数据库中的数据。

准备工作

我们需要什么样的环境和工具?

1)我使用了Oracle8i、IIS5.0、Windows2000专业版作为应用程序的开发和运行环境。

2)在Oracle数据库中建立一个名字为MYTABLE1或类似的表。

ID (type: number)

User Name(type: varchar2)

Phone(type: varchar2)

Email(type: varchar2)

100

Colin Tong

999-999-8888

colinjava@hotmail.com

111

John White

888-888-8888

johnw@yahoo.com

101

Don Wod

416-333-3344

donwod@test.com

数据的访问和存取

1) Instantiate OO4O Object, OraSession

and interface OraDatabase for connecting to ORACLE.

1)初始化Oracle

Objects for OLE、OraSession对象和OraDatabase接口,为连接ORACLE数据库作准备。

首先,使用CreateObject创建OraSession对象,然后通过打开一个与Oracle的连接创建OraDatabase对象,如下所示:

<%

Set OraSession = CreateObject("OracleInProcServer.XOraSession")

Set OraDatabase = OraSession.OpenDatabase("", _

"username/password",

Cint(0))

%>

“username”和“password”是你所使用的关系数据库的用户名和口令。

2)创建OraDynaset对象执行SQL命令。我们可以使用CreateDynaset或DbCreateDynaset创建记录集。

<%

'execute SQL

Set OraDynaset = OraDatabase.DbCreateDynaset( _

"select * from mytable1", cint(0))

%>

3)存取数据并删除创建的对象。

<%

Do While(OraDynaset.EOF = FALSE)

Response.write(OraDynaset.Fields("ID"))

Response.write(OraDynaset.Fields("UserName"))

... others ...

... ...

OraDynaset.MoveNext

Loop

'remove OraSession

Set OraSession =

Nothing

%>

编辑数据记录

我们将使用OraDynaset的方法实现对数据记录的编辑。

1)使用SQL语句创建OraDynaset对象。

<%

'创建ID= fID的记录的OraDynaset对象。

Set OraDynaset =

OraDatabase.CreateDynaset(_

"select * from MYTABLE1 where ID= "& fID,

cint(0))

%>

fID是想插入更更新的记录的ID值。

2)执行OraDynaset更新或添加数据记录。

<%

'使用Edit方法更新ID=fID记录的域。

'或使用AddNew插入一个新记录

OraDynaset.Edit

OraDynaset.Fields("Phone").Value = fPhone

OraDynaset.Update

' 删除创建的对话

Set OraSession = Nothing

%>

删除数据记录

如果已经真正地理解了我们在上面讨论的一些方法(Edit、Update和AddNew),也许有的读者已经知道该如何在Oracle数据库中删除记录了。

<%

'删除所有符合上面条件的记录

OraDynaset.Delete

%>

在Oracle8i中搜索和更新数据记录的代码

1)搜索

<%

'RetriveRecProc.asp -使用ASP的Oracle Objects for OLE更新数据记录%>

<%

'定义作为OLE对象的变量

Dim OraSession

Dim OraDatabase

Dim

OraDynaset'创建OraSession对象

Set OraSession =

CreateObject("OracleInProcServer.XOraSession")'通过打开Oracle数据库的一个连接创建OraDatabase对象

'一定要使用自己的用户名和口令访问Oracle数据库

Set OraDatabase = OraSession.OpenDatabase("",

"user/password", _

Cint(0))

'创建OraDynaset对象执行SQL语句

Set

OraDynaset = OraDatabase.DbCreateDynaset(_

"select * from mytable1",

cint(0))

%>

<html><body>

<H3>Retrieve All Records in MYTABLE1 Table

( in Oracle)

Using oo4o</H3>

<table border=1 ID="Table1">

<%

Do

While(OraDynaset.EOF = FALSE)

Response.Write("<tr><td>")

Response.write(OraDynaset.Fields("ID"))

Response.Write("</td><td>")

Response.write(OraDynaset.Fields("UserName"))

Response.Write("</td><td>")

Response.write(OraDynaset.Fields("Phone"))

Response.Write("</td><td>")

Response.write(OraDynaset.Fields("Email"))

Response.Write("</td></tr>")

OraDynaset.MoveNext

Loop

'删除OraSession

Set OraSession = Nothing

%>

</table>

<a

href="javascript:window.history.go(-1)">

Back previous Page</a> |

<a

href="index.html"> Back home Page</a>

</body></html>

2)更新

<%

'UpdateRecProc.asp -使用ASP的Oracle Objects for OLE更新数据记录

%>

<%

'定义作为OLE对象的变量。

Dim OraSession

Dim OraDatabase

Dim OraDynaset

'从提交的表格中获取字段值

fID = request.form("ID")

fUserName =

request.form("UserName")

fPhone = request.form("Phone")

fEmail =

request.form("Email")

'创建OraSession对象

Set OraSession =

CreateObject("OracleInProcServer.XOraSession")

'通过打开Oracle数据库的一个连接创建OraDatabase对象

Set OraDatabase =

OraSession.OpenDatabase("", "user/password", _

Cint(0))

'创建ID=

fID的记录的OraDynaset对象

Set OraDynaset = OraDatabase.CreateDynaset(_

"select

* from MYTABLE1 where ID= "& fID, cint(0))

'使用Edit方法更新ID=fID记录的字段

Do

While(OraDynaset.EOF = FALSE)

OraDynaset.Edit

OraDynaset.Fields("UserName").Value = fUserName

OraDynaset.Fields("Phone").Value = fPhone

OraDynaset.Fields("Email").Value = fEmail

OraDynaset.Update

OraDynaset.MoveNext

Loop

%>

<html><body>

<H3>Update A Record

in MYTABLE1 Table (Oracle) Using oo4o</H3>

The record (ID=<%=fID%>) has been

updated successfully!<br>

You can view the result <a

href="RetrieveAllRec.asp"> here</a>

<p>

<a

href="javascript:window.history.go(-1)"> Back previous Page</a>

&bnsp;&bnsp;

<a href="javascript:window.history.go(-2)"> Back

home Page</a>

<%

'删除OraSession对象

Set OraSession = Nothing

%>

</body荆?html>

至此,我们已经讨论了如何在ASP代码中使用Oracle Objects for OLE来处理Oracle数据库中的数据。

使用存储过程

我们已经讨论了如何在ASP中访问Oracle数据库,所有的SQL语句都可以嵌入在ASP网页中。如果在ASP中使用存储过程,将更能够更有效地处理数据。我建议读者除在ASP中嵌入SQL语句外,还应当使用PL/SQL存储过程。在Oracle数据库中创建存储过程已经超出了本文章的范围,在这里就不再进行介绍了。

ASP和Oracle数据库是二种比较流行的技术,都有相当广泛的用户群,如果能够有机地将二者结合起来,将能够给工作带来许多方便,希望这篇文章能够起到抛砖引玉的作用,使读者能够更好地探索将这二种技术结合使用的途径。

二.

dim objorasession,objoradb

dim strdbuser,strdbpwd,strdbconn

call connectdb()

sub connectdb()

连接数据库

on error resume next

strdbuser = "tmpuser" 连接用户名

strdbpwd = "rt45ps1w" 用户密码

strdbconn =

"sun450" 连接字符串

set objorasession =

server.createobject("oracleinprocserver.xorasession")

set objoradb =

objorasession.opendatabase(strdbconn,strdbuser & "/" & strdbpwd,0)

if err.number>0 then

response.write "错误 :"

& err.description & ""

response.end

end if

end

sub

sub enddb()

set objoradb = nothing

set objorasession = nothing

end sub

function gettablelist(str)

dim strsql,strtmp

dim objrs

strsql = "select at.table_name as tname,au.username as uname from all_tables

at,all_users au where au.username=at.owner order by au.username"

set objrs =

objoradb.dbcreatedynaset(strsql,0)

while not objrs.eof

stra =

objrs("uname") & "." & objrs("tname")

if str=stra then

strtmp =

strtmp & "" & stra & ""

else

strtmp = strtmp & "" & stra &

""

end if

objrs.movenext

wend

set objrs = nothing

gettablelist = strtmp

end function

%>

action="index.asp" method=post target="main">

border=0 align="center">

all tables :

name="tb">

type=submit name="submit" value="view data">

color=red>(

strdbconn%>)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 首先设置网上购物系统。 (1) 确认“JDK+Tomcat”的运行环境已经搭建好。 (2) 从光盘中将shopping目录拷贝到电脑中,这里假定拷贝在“D:\shopping”,即把包含了网上购物系统所有文件的shopping目录放到D盘中。 (3) 在Tomcat安装目录的conf\Catalina\localhost目录下新建一个shop.xml配置文件,在其中添加一个Context元素,代码如下: (4) 将Oracle驱动程序“classes12.jar”(从Oracle安装目录,例如C:\oracle中搜索)拷贝到Tomcat安装目录下的 common\lib子目录中。 2. 在正式运行这个网上购物系统之前,要先建立相应的数据库和表,操作如下。 (1) 建立Oracle数据库。 对于本网上购物系统,我们需要建立一个名为myorc的Oracle数据库。具体创建方法可以参考本书第5章的内容(需建立SCOTT账户)。 (2) 通过PL/SQL Developer直接导入光盘中提供的数据记录,方法如下: ①在PL/SQL Developer工具中以SCOTT用户身份登录Oracle数据库myorc(请注意使用Normal登录!)。 ②选择【工具】|【导入表】菜单命令,选择“SQL插入”选项卡,然后导入“D:/shopping/数据库/shop.sql”文件,接着选择“Oracle导入”选项卡,然后导入“D:/shopping/数据库/shop.dmp”文件,这样,我们就成功地导入了对象和表数据。 3. 到此,网上购物系统已经可以正常运行了。 (1) 启动Tomcat服务器。 (2) 打开浏览器,在地址栏中输入http://localhost:8080/shop,即可打开网上购物系统登录界面。 (3) 注册新用户,然后使用注册时使用的用户名和密码登录网上购物系统。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值