如何在pb中创建COM组件 并在asp中调用并返回结果集?

2016-01-29 18:45 61 1 收藏

如何在pb中创建COM组件 并在asp中调用并返回结果集?,如何在pb中创建COM组件,并在asp中调用并返回结果集?

【 tulaoshi.com - ASP 】

 

启动pb7.0,创建一个不可视的用户对象"uo_customer",新建"object",选择"custom  class"
类型,点击"ok"。
在新创建的用户对象中编写如下程序:
1.声明实例变量"instance  variables",对于com中不支持的类型,请声明为protected类型。protected:
datastore  ds_datastore
2.新建三个成员函数:
int  uf_connect()//用于连结数据库与创建datastore对象。
代码:
sqlca.dbms="odbc"
sqlca.database="webdw"
sqlca.autocommit=false
sqlca.dbparm="connectstring=''dsn=webdw;uid=dba;pwd=sql''"
connect  using  sqlca;
ds_datastore  =create  datastore
if  sqlca.sqlcode=0  then
    return  1
else
    return  -1
end  if

void  uf_disconnect()//用于断开数据库连结和释放datastore对象。
if  isvalid(ds_datastore)  then  destroy  ds_datastore
disconnect  using  sqlca;


resultset  uf_retrieve()//读取客户信息
resultset  lrs_customers
ds_datastore.dataobject="d_customer"
ds_datastore.retrieve()
ds_datastore.generateresultset(lrs_customers)//生成结果集
return  lrs_customers//返回结果集
最后,保存改对象为"uo_customers"。

制作一个com组件的工程
新建"project",选择"Com/mts  component  wizard",确定。
给工程定义一个名字"p_recordset_com"
接下来,选择要生成com的用户对象"uo_customer"
设置生成com组件后的接口属性,这里可以使用缺省。
然后自己定义组件的program  id为"pb70.uocustomer",
然后选择该com组件的dll文件名,单击"new",生成"component  server  appid",
同样生成"type  library  id",最后,选择pb资源文件名,以及注册方式,之后,系统会
给出用户设置的大致信息,然后选择生成"to  do  list"
这样就完成一个生成com组件的工程,名为"p_test_com"。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/asp/)

编译工程并注册组件
打开已经生成的工程,选择相应的pbl文件及用户对象,编译就可以了

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/asp/)

下面我们创建asp网页来调用这个pb  com
<head<titlepb  com</title</head
<body
<%
set  customers=server.createobject("pb70.uo_customers")
iflag=customers.uf_connect()
set  rs=customers.uf_retrieve()
'www.knowsky.com
%
<table
<%rs.movefirst
do  while  not  rs.eof
%
<tr
<td<%=rs("lname")%</td
<td<%=rs("address")%</td
<td<%=rs("city")%</td
</tr
<%rs.movenext
loop
rs.close
customers.uf_disconnect()
%
</table
</body
保存成asp文件

最后,在浏览器中就可以浏览这个asp文件了

说明:pb7.0和pb8.0基本上差不多,读者可以自己实践。

 

来源:http://www.tulaoshi.com/n/20160129/1507188.html

延伸阅读
标签: ASP
  /* -----------------------------------     产生论坛分类目录内容表过程    -----------------------------------    */ CREATE PROCEDURE sp_createnew_bbscontent     @tabname varchar(200)='',     @boardid int AS  &nbs...
Java跨平台的特性使Java越来越受开发人员的欢迎,但也往往会听到不少的抱怨:用Java开发的图形用户窗口界面每次在启动的时候都会跳出一个控制台窗口,这个控制台窗口让本来非常棒的界面失色不少。怎么能够让通过Java开发的GUI程序不弹出Java的控制台窗口呢?其实现在很多流行的开发环境例如JBuilder、Eclipse都是使用纯Java开发的集成环境...
       一、Java中的远程方法调用 远程方法调用(Remote Method Invocation, RMI)是Java1.1引入的分布式对象软件包,它的出现简化了在多台机器上的Java应用之间的通信。相比CORBA,RMI功能较弱且只能用于Java系统。 二、实现一个简单的RMI 要使用RMI,必须构造四个主要的类:远...
 使用Component编程是一项值得推崇的技术,它既具有可视化的界面编程模式,又不向UserControl那样体积庞大。但是,熟悉UserControl的朋友们都知道,在UserControl类中有一个FindForm()函数,返回UserControl所在的窗体的引用,这将大大方便我们对窗体的控制----尽管这可能有些越俎代庖的味道,但有时我们就需要这种控制能力。   ...
标签: Delphi
  众所周知,ASP技术是我们在以internet/intranet为平台的web程序的主要技术,在asp应用程序中我们一般使用vbscripts和javascripts两种脚本语言。但是脚本语言是一种非编译的语言,其所开发的web程序存在先天的安全性、执行效率扩张性方面的问题,因此我们一般在开发web系统时用高级语言编写asp执行体,然后用脚本语言作为连接代码...

经验教程

263

收藏

21
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部