祝愿大家身体健康!

 站点注册  找回密码
 站点注册

QQ登录

只需一步,快速开始

查看: 7201|回复: 5

PB中的DataStore是个好东西

[复制链接]

PB中的DataStore是个好东西

[复制链接]
ehxz

主题

0

回帖

58万

积分

管理员

积分
588531
贡献
在线时间
小时
2011-5-28 16:27:15 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?站点注册

×
编程过程中想在窗口中加一个下拉列表(DDLB),原来听同学说过可以动态改变下拉列表的值,数据库中的表改变,前台客户端的下拉列表就会变,记得当时同学说的是用一个叫下拉数据窗口(DDDW)的东西做的,一直没试过,今天遇到了这样的问题,想试一下,于是在网上查找例子,但似乎都不合我的意,下面简单说下需求:

涉及表:

1、dm_yhzl (银行种类代码表)

字段:yhzl _dm(银行种类代码,如1100、1200等) ,yhzl_mc(银行种类名称,如中国工商银行等)

2、dm_yh(银行名称代码表)

字段:yhzl_dm(银行种类代码),yh_dm(银行代码,如1101等),yh_mc(具体银行名称)

需求:窗口中有一个下拉列表,里面的ITEM中包含dm_yhzl中所有的银行种类,下拉列表中的内容随着银行种类代码表中数据增加而增加,然后数据窗口中的具体银行信息为下拉列表中银行种类下的所有分行等信息。



实现:因听同学说DDDW可以连接到数据表进行取数,开始便想试着弄一下,但DDDW好像只能在数据窗口中使用,如Freeform等类型的数据窗口,但我想要的是窗口中的DDLB,所以不满足我的需求,于是想到了用游标的方式来实现,于是上网查询游标的使用方法(原来没用过,小白一下),但PBer们好像都反映游标不好用,查询速度慢,建议使用DataStore来代替游标,于是便又接触到了新鲜事物:DataStore(哈,再小白一下),根据网上的介绍,感觉应该可以满足我的需求,于是试着做了起来。



第一步,创建一个数据窗口(Grid型),选择dm_yhzl表中的两列,如需过滤可设置where条件等,起名为dw_yhzl。

第二步,再创建一个Grid型的银行信息数据窗口,选择dm_yh中的yh_dm和yh_mc列,起名为dw_yh。

第三步,在窗口控件中添加下拉列表(DDLB),起名为ddlb_yhzl,下面添加数据窗口控件,对应的数据窗口为刚才建立的dw_yh。

第四步,在窗口控件的open事件中写如下代码:

string ls_yhzl

long ll_row,ll_row_count



datastore ds_yhzl   //声明Datastore变量

ds_yhzl = create datastore   //将Datastore实例化

ds_yhzl.dataobject = "dw_yhzl"   //为datastore分配数据窗口对象

ds_yhzl.settransobject(sqlca)   //指定连接实例

ds_yhzl.retrieve()   //提取数据



ll_row_count = ds_yhzl.rowcount()   //将所取数据的行数存储在ll_row_count变量中



for ll_row = 1 to ll_row_count   //创建循环语句进行取值

   ls_yhzl = ds_yhzl.getitemstring(ll_row,"yhzl_mc")    //取当前行的yhzl_mc字段对应的值

   ddlb_yhzl.additem(ls_yhzl)   //将取到的当前行的值添加到下拉列表中

next       //取下一条记录

destroy ds_yhzl   //释放datastore



通过以上操作,在打开窗口控件时,下拉列表中自动添加了银行种类代码表中的所有银行种类,想查询银行种类下的具体银行信息,可以添加查询按钮,在查询按钮的clicked事件中添加如下代码(也可以在下拉列表的selectionchanged事件中添加,但数据较多时可能会速度慢):

string old_select,setselect,setwhere

old_select=dw_1.describe("datawindow.table.sqlselect")   //将当前数据窗口的SQL语句存入变量old_select

setselect="select yh_dm,yh_mc from dm_yhzl a,dm_yh b "   //设置select语句,注意最后的双引号前要加一个空格

setwhere="a.yhzl_dm=b.yhzl_dm"   //设置where条件

if trim(ddlb_yhzl.text)<>'' then   //如果在下拉列表中选择了银行种类,则在查询条件中加入如下条件语句

   setwhere+=" and a.yhzl_mc=' " + ddbl_yhzl.text + " ' "

end if

dw_1.object.datawindow.table.select=setselect+setwhere   //动态修改数据窗口的查询语句

dw_1.settransobject(sqlca)   //指定连接实例

dw_1.retrieve()   //按修改后的条件提取数据

dw_1.object.datawindow.table.select=old_select   //将数据窗口的查询语句重置为原来的查询语句



好了,大功告成,运行程序,打开窗口,下拉列表中出现了所有银行种类,如不进行选择,点击查询按钮,数据窗口中显示出所有银行信息,如工行的各分行、建行的各分行、农行的各分行等。如果在银行种类中选择中国工商银行,点击查询控钮,则列出工行的所有分行信息。

在此例中学到了datastore的应用,感觉非常有用,这样使用后,如果有新的银行信息加入时,只要对数据库中的银行种类表进行维护,客户端的下拉列表即可同时更新,非常方便。
共享共进共赢Sharing And Win-win Results
SYBASEBBS - 免责申明1、欢迎访问“SYBASEBBS.COM”,本文内容及相关资源来源于网络,版权归版权方所有!本站原创内容版权归本站所有,请勿转载!
2、本文内容仅代表作者观点,不代表本站立场,作者自负,本站资源仅供学习研究,请勿非法使用,否则后果自负!请下载后24小时内删除!
3、本文内容,包括但不限于源码、文字、图片等,仅供参考。本站不对其安全性,正确性等作出保证。但本站会尽量审核会员发表的内容。
4、如本帖侵犯到任何版权问题,请立即告知本站 ,本站将及时删除并致以最深的歉意!客服邮箱:admin@sybasebbs.com
fuxiaoyang13

主题

0

回帖

3136

积分

论坛元老

积分
3136
贡献
在线时间
小时
2011-7-19 17:22:17 | 显示全部楼层
学习学习!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
共享共进共赢Sharing And Win-win Results
yuer

主题

0

回帖

622

积分

高级会员

积分
622
贡献
在线时间
小时
2011-7-20 15:37:47 | 显示全部楼层
真好学习pb的人很多 加油。哦
共享共进共赢Sharing And Win-win Results
j528

主题

0

回帖

3254

积分

论坛元老

积分
3254
贡献
在线时间
小时
2013-4-27 12:27:05 | 显示全部楼层
非常好的例子
共享共进共赢Sharing And Win-win Results
liqipeng182

主题

0

回帖

8884

积分

论坛元老

积分
8884
贡献
在线时间
小时
2013-10-5 22:31:46 | 显示全部楼层
谢谢分享!!很好的例子
共享共进共赢Sharing And Win-win Results
吞吞

主题

0

回帖

189

积分

注册会员

积分
189
贡献
在线时间
小时
2014-10-2 22:29:25 | 显示全部楼层
哈, 这是我写的例子,都被转这来了,互相学习了
共享共进共赢Sharing And Win-win Results
您需要登录后才可以回帖 登录 | 站点注册

本版积分规则

免责声明:
本站所发布的一切破解补丁、注册机和注册信息及软件的解密分析文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:Admin@SybaseBbs.com

QQ|Archiver|PowerBuilder(PB)BBS社区 ( 鲁ICP备2021027222号-1 )

GMT+8, 2024-11-21 23:40 , Processed in 0.036809 second(s), 8 queries , MemCached On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表