在powerbuilder中使下拉列表框可以和数据关联

转载 2012年04月05日 16:18:55

在powerbuilder中使下拉列表框可以和数据关联

(加入日期:2002-4-20)

保存文章至硬盘】【打印文章】【字体:

分享到: 0
  在从事使用powerbuilder进行数据库开发的过程中,常常碰到要使用列表框来选择数据,但是普通的下拉列表框并没有提供和数据相连接的方法,而使用数据窗口的子下拉列表框来代替又显得有些别扭.下面介绍一种好看又好用的方法.
  可能大家已经想到了吧,使用指针把要连接的数据一条一条地从select 语句的查询结果中fetch 出来,然后再把数据additem到下拉列表框中去.
  虽然这也是一种可行的方法,但是他的速度很不能令人满意,太受数据量的影响.
  我们可以利用powerbuilder 最推崇的数据窗口技术作为数据库和下拉列表框连接的桥梁,这种方法即方便快速又安全可靠.
好了,下面制作的下拉列表框,在完成之后会带给你许多意想不到的方便!

一. 打开powerbuilder的"select user object"画笔,选择<new>, 在"new user object"中选择"Visual"类的"Standard"项并按下<ok>, 在弹出来的"Select Standard Visual Type"对话框中选择列表中的 "dropdownlistbox"项并按下<ok>. 接着加入一些实例变量,选择"Declare"菜单项的"Instance Variables.."
加入变量的声明: datastore ids_user int il_row 并按下<ok>.
我们要对新的对象进行一些限制,在对象的"constructor"事件中加入 程序:
sorted = false //这句非常必要
reset()

二. 好了,现在到了最关键的时候了,我们要把数据检索出来放到ids_user
变量里.
选择菜单"Declare"项的"User Object Function",在弹出来的对话框
中按下<new>新建一个对象函数命名为:
init
参数有一个:
sqlstr string
返回值为整型:integer
现在我们需要动态地创建datastore
在init函数中写下:
//integer init(sqlstr string) 开始
long ll_rowcount
long ll_row
string ls_sql
string errors
string ls_return
ids_user = create datastore
//根据sql语句产生数据窗口
ls_return = sqlca.SyntaxFromSQL(sqlstr, 'style(type=grid)',errors)
//sql语句有错误
if len(errors) > 0 then
messagebox('错误', errors)
return -1
end if
//根据语法动态创建数据窗口
ids_user.create(ls_return)
ids_user.settransobject(sqlca)
ll_rowcount = ids_user.retrieve()
//无数据返回
if ll_rowcount=0 then
return -1
end if
//把数据插入控件
for ll_row = 1 to ll_rowcount
this.additem(string(ids_user.Object.Data[ll_row,1]))
next
//成功返回0
return 0
//integer init(sqlstr string) 结束

现在下拉列表框已经能显示数据了,但是我们在选择数据的同时往往
需要的不是它显示出来的值,比如显示的是人员姓名,而我们需要的
是工号,难道再使用select语句把需要的数据检索出来吗?有了下面的
程序,我们就不必头痛了.
重复上面建立函数的步骤,新建一个名为getdata的user object函数,
返回值为"any"并在函数中写下程序:
//any getdata() 开始
any la_return
long ll_row
if text = '' then
return ''
end if
//没有选择或没有检索到数据
if ids_user.rowcount() = 0 or il_row = 0 then
return ''
end if
//在缺省情况下返回第二列的数据
la_return = ids_user.Object.data[il_row, 2]
return la_return
//andy getdata() 结束

现在还不能返回正确的数据,还需要一个函数setidx(idx int)
程序如下:
//setidx(idx int) 开始
il_row = idx
//setidx(idx int) 结束

现在这个user object已经完成了,我们来做一下试验试一试.
新建一个应用app_test,一个窗口w_main,按照刚才的方法创
建一个user object:uo_dbdropdownlistbox,放入w_main中
在app_test的open事件中写下连接数据库的语句并加上open(w_main)
在w_main的open事件中写下:
int li_result
li_result = uo_1.init('select name, id from sysobjects')
在uo_1的selectionchanged事件中写下:
setidx(index)
messagebox('提示', "看" + string(this.getdata()))
这时我们的用户对象已经能根据选择的name返回相应的id了.
至于更多的功能,还有待powerbuilder的爱好者们不断地思考
创造了.如果还想深入讨论请和我联系:fly-back@163.com

JSP 下拉框实现值联动实例

下拉框值联动测试 var fjyt=[["NCR","DC","OTHER"], ["NCR","DC","OTHER"], ["NCR","DC","OTHER"],...
  • wanglei880526
  • wanglei880526
  • 2014年04月15日 14:16
  • 7781

html的下拉框的几个基本用法

虽然使用EXT开发了一段时间,但是自己觉得我对javascript还是不是很熟,所以边看书边做小例子 给自己以后用到的时候查看下,都是很基本的东西,对初学者可能有点帮助 下面是代码 ...
  • seelye
  • seelye
  • 2013年01月07日 11:21
  • 131071

jeecg下拉框功能的实现

接下来我们介绍的只是jeecg中的一种下拉框的使用方法,用到的是replace方法,首先我们贴一下代码: ...
  • Aeyewp
  • Aeyewp
  • 2017年04月06日 21:55
  • 2182

ACCESS 双表自动查询数据(下拉列表框)

  • 2010年12月05日 06:22
  • 22KB
  • 下载

【PB】使用参数指定的SQL语句向指定的下拉列表框中添加数据

////////////////////////////////////////////////////////////////////////////////////////////////////...
  • lijianhe043
  • lijianhe043
  • 2011年12月30日 16:44
  • 2207

esayui--下拉列表框只能选择当前数据往后的(不可逆的)

1.下拉列表框中的所有的效果图 2.只能选择当前选中的和后面的 3.jsp代码 执行状态 ...
  • qq_35995940
  • qq_35995940
  • 2017年10月26日 11:12
  • 92

三级联动下拉列表框(SELECT)jquery插件(js 三级联动) php版

  • 2011年11月25日 18:20
  • 35KB
  • 下载

C#美化ComboBox的源码,为下拉列表框着色

  • 2013年07月31日 21:14
  • 18KB
  • 下载

下拉列表框

  • 2014年10月14日 22:59
  • 4KB
  • 下载

无刷新联动下拉列表框

  • 2008年06月28日 16:52
  • 22KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在powerbuilder中使下拉列表框可以和数据关联
举报原因:
原因补充:

(最多只允许输入30个字)