欢迎光临
我们一直在努力

在ASP中使用Oracle数据库技巧-ASP教程,数据库相关

建站超值云服务器,限时71元/月

  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.   

  

  初始化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>

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

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 在ASP中使用Oracle数据库技巧-ASP教程,数据库相关
分享到: 更多 (0)