您的位置:软件 > 开发者网络 > 开发工具 > 开发专栏 > PB > 正文
PB环境下分布式应用程序的开发
[文章信息]
作者:郑华
时间:2003-06-05
出处:yesky
责任编辑:方舟
[文章导读]
本文将介绍如何应用PowerBuilder进行分布式应用程序的开发
advertisement
热点推荐
· 11.15软件精选 制作MSI文件
· 闪客五周年之闪客光荣榜
· 用Winamp“品尝”无限音乐
· 网络加、解密的技术应用
· 闪客五周年之闪客光荣榜:zoron
[正文]

上一页  1 2  

  三、实例

  先看如下两个图,图二表示DTS端,图三表示Client端。其中DTS已经建立了与数据库服务器的连接,数据窗口中显示的是所有的数据;Client并没有数据库接口,而是通过DTS间接的访问数据,在数据窗口中显示的是所有男性职工。


图(二)


图(三)

  该程序的大部分源代码如下:

  DTS端:

  1、首先定义一个全局变量:Transport mytrans;

  2、在"开始监听"按钮中输入如下代码:

long ll
mytrans=create transport
mytrans.driver="winsock"
mytrans.application="5000" //端口号
mytrans.location="." //本地服务器
ll=mytrans.listen() //开始监听
if ll<>0 then
messagebox(string(mytrans.errcode),mytrans.errtext)
return
end if
server.settranspool(12,16,10) //设置连接缓冲,注意"server"为应用的名称
this.text="正在监听中..."
this.enabled=false

  3、在"结束监听"按钮中输入如下代码:

mytrans.stoplistening() //结束监听
destroy mytrans
cb_1.text="开始监听"
cb_1.enabled=true

  4、建立一个NVO:

  利用PB的User Objects画板建立一个classàcustom的用户对象,建立用户对象函数nvoretrieve(ref blob buffer,string filter) returns long,函数体如下:

long ll
SQLCA.DBMS = "ODBC"
SQLCA.AutoCommit = False
SQLCA.DBParm = "Connectstring='DSN=person'"
connect; //建立与数据库的连接
datastore datastore_buffer
datastore_buffer=create datastore
datastore_buffer.dataobject="dw_person" //dw_person是一个数据窗口
datastore_buffer.settransobject(sqlca)
datastore_buffer.retrieve()
datastore_buffer.setfilter(filter)
datastore_buffer.filter()
ll=datastore_buffer.getfullstate(buffer) //函数getfullstate()和setfullstate()常用于分布式应用程序。
disconnect;
return ll

  5、建立NVO的代理对象

  在用户对象上点鼠标右健,选择"Set Proxy Name",输入"NVO_dw",保存用户对象。

  打开Library画板,将"NVO_dw"输出为文件,以便在客户端导入该代理。

  Client端:

   1、打开Library画板,将刚才输出的文件导入

   2、定义两个全局变量:

connection myconn
nvo_dw proxy_dw

   3、在"连接"按钮中输入如下代码:

long ll
myconn=create connection
myconn.driver="winsock"
myconn.application="5000" //必须和DTS端的端口号一致
myconn.location="192.168.6.1" //DTS的IP地址
ll=myconn.connecttoserver() //建立连接
if ll<>0 then
messagebox(string(myconn.errcode),myconn.errtext)
return
end if
this.text="正在连接中..."
this.enabled=false
cb_2.enabled=true
cb_3.enabled=true

  3、在"断开"按钮中输入如下代码:

myconn.disconnectserver() //断开连接
destroy myconn
cb_1.enabled=true
cb_1.text="连接"
cb_3.enabled=false
this.enabled=false

  4、在"查询"按钮中输入如下代码:

long result
blob buffer
myconn.createinstance(proxy_dw) //建立代理对象
result=proxy_dw.nvoretrieve(buffer,"sex='男'") //检索所有男性职工
result=dw_1.setfullstate(buffer) //dw_1是一个数据窗口控件

  四、小结及注意事项

  1、以上程序在WINDOWS'98、PB6.0环境中调试通过,在客户数量很多,数据量很大的情况下,查询的速度会快很多。

  2、编程时注意,如果NVO的函数体发生变化,则无须重新生成代理;如果NVO的函数接口发生变化,则必须重新生成它的代理并将它输入到客户端中。

  3、NVO对象是一个不可视对象,只能通过函数调用的方法使用它,不可将它作为一个控件放在窗口上。


上一页  1 2  

·"WAP天极之IT新闻资讯,50万元等你拿"    ·天极WAP之游戏狂图,50万元等你下载

天极社区邀请您:写博客日记  上传相片   论坛聊天  订阅电子杂志  推荐网摘   免费图铃工具
笔名:   请您注意:

 遵守国家有关法律、法规,尊重网上道德,承担一切因您的行为而直接或间接引起的法律责任。

 天极网拥有管理笔名和留言的一切权利。
评论:
 

发表评论推荐给朋友我想参加相关培训打印我对此感兴趣订阅电子杂志
相关内容阅读排行榜
  • PB/Sybase系统开发中的数据库转移
  • 11.15软件精选 制作MSI文件
  • 闪客五周年之闪客光荣榜
  • 兰欣推出我国第一款网络游戏专用音箱
  • 玩家发现117亡灵种族Bug
  • [配置推荐]极品HIFI配置
  • 东瀛美少女COSPLAY(55)
  • 用Winamp“品尝”无限音乐
  • 迷你型PStwo全面透析专题
  • Advertisement