征集网锐志网络淘途找素材上91
创意在线首页
平面设计交互设计CG动漫工业设计建筑环境数码影像创意搜
 首页大赛征集资讯教程画廊访谈作品集创企同盟设计招聘人才专区竞赛台专题论吧 找素材看酷站设计网址库
教程网 Illustrator、Photoshop、CoreaDreaw、AI教程、PS教程
当前位置:首页 > 教程 > 程序相关 > 正文
在ASP中使用Oracle数据库技巧
作者: 来源:52design.com 发表时间:2007-8-30 17:12:57 浏览:
    Oracle是世界上用得最多的数据库之一,活动服务器网页(ASP)是一种被广泛用于创建动态网页的功能强大的服务器端脚本语言。许多ASP开发人员一直在考虑,能否在开发互联网应用、电子商务网站、互联网管理系统时结合使用ASP和Oracle数据库?这个问题的答案是肯定的,我们还可以使用VB访问Oracle数据库。在本篇文章中,我们将主要讨论如何使用ASP来处理Oracle数据库中数据的方法。
·设计师个人作品集火热申请中!
·查询网站排名推荐您用Chianz排名查询
·“论吧”正式上线 欢迎参与主题讨论
·全球经典酷站推荐欣赏
·矢量素材 给设计师提供强大后盾
·加入设计师论坛,精彩无限
·设计网址大全,免费收录所有设计站点

   
    在开始讨论这个问题前,我们需要了解几个背景知识,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.   
    
    初始化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)
  
  
&nbs

在线编辑:morion
本文链接:


推荐阅读:
·2021第十五届“创意中国”设计大奖 征稿章程
·2021第七届“学院派奖”全国艺术与设计大赛征集公告
·青春唯美插画培训网络远程班正在招生
·第八届中国高等院校设计作品大赛启动
·第十二届中国高校美术作品学年展获奖名单公布
·2021第七届“学院派奖”全国艺术与设计大赛征集公告
·第六届“包豪斯奖”国际设计大赛获奖名单揭晓
免责声明:本站刊载此文不代表同意其说法或描述,仅为提供更多信息。对本文有异议,请联络本站!
转载要求:文章作者及来源信息必需保留。转载之图片、文件请不要盗链本站地址,且不准打上各自站点的水印!

近期推荐报道 返回首页更多精彩等着你!

Photoshop| Photoshop快速调出情侣图片柔美的插画艺术| 绝望的小熊—美国插画师Luke
网页设计| 波兰Tiquet网站设计作品欣赏插画艺术| Nanami Cowdroy灵动黑白插画
Photoshop| Photoshop调出美女图片绚丽的橙红HTML/CSS| 实现DIV透明而里面的文字不透明
平面设计| 世界杯之平面广告欣赏插画艺术| Alberto Cerrite&ntil
平面设计| Havaianas人字拖最新平面广告系列网页设计| 英国madefavourite简洁细腻型
关于本站 | 联系方式 | 商业服务 | 合作伙伴 | 站点地图 | 免责声明 | 版权声明 | 在线投稿