问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

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

发布网友 发布时间:2023-06-05 02:05

我来回答

1个回答

热心网友 时间:2023-10-05 07:13

  在从事使用powerbuilder进行数据库开发的过程中 常常碰到要使用列表框来选择数据 但是普通的下拉列表框并没有提供和数据相连接的方法 而使用数据窗口的子下拉列表框来代替又显得有些别扭 下面介绍一种好看又好用的方法

  如果使用指针把要连接的数据一条一条地从select 语句的查询结果中fetch 出来 然后再把数据additem到下拉列表框中去 虽然这也是一种可行的方法 但是他的速度不能令人满意 太受数据量的影响 我们可以利用powerbuilder 最推崇的数据窗*术作为数据库和下拉列表框连接的桥梁 这种方法即方便快速又安全可靠

  下面制作的下拉列表框

  一 打开powerbuilder的 select user object 画笔 选择 在 new user object 中选择 Visual 类的 Standard 项并按下 在弹出来的 Select Standard Visual Type 对话框中选择列表中的 dropdownlistbox 项并按下 接着加入一些实例变量 选择 Declare 菜单项的 Instance Variables 加入变量的声明 datastore ids_user int il_row 并按下

  我们要对新的对象进行一些* 在对象的 constructor 事件中加入程序

  sorted = false //这句非常必要

  reset()

  二 把数据检索出来放到ids_user变量里

  选择菜单 Declare 项的 User Object Function 在弹出来的对话框中按下新建一个对象函数命名为 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) > then

  messagebox( 错误 errors)

  return

  end if

  //根据语法动态创建数据窗口

  ids_user create(ls_return)

  ids_user settransobject(sqlca)

  ll_rowcount = ids_user retrieve()

  //无数据返回

  if ll_rowcount= then

  return

  end if

  //把数据插入控件

  for ll_row = to ll_rowcount

  this additem(string(ids_user Object Data[ll_row ]))

  next

  //成功返回

  return

  //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() = or il_row = then

  return

  end if

  //在缺省情况下返回第二列的数据

  la_return = ids_user Object data[il_row ]

  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_ init( select name id from sysobjects )

  在uo_ 的selectionchanged事件中写下 setidx(index)

  messagebox( 提示 看 + string(this getdata()))

  这时我们的用户对象已经能根据选择的name返回相应的id了

       编辑推荐

  数据仓库与数据挖掘培训视频教程

lishixin/Article/program/PB/201311/24638
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
变形金刚08动画怎么样 变形金刚08动画的问题 变形金刚08动画日语版剧情介绍 高分!换显卡nvidia控制面板被我卸了,重新安装显卡驱动后没了nvidia控... 我的nvidia控制面板被卸载了 怎么找回啊 卸载后 这个画面看着很奇怪_百 ... 李卓彬工作简历 林少明工作简历 广东工业职业技术学院怎么样 郑德涛任职简历 唐新桂个人简历 高性能MySQL:集成式测试工具 如何计算汽车保险费? Sell和we和slept他们当中的e,哪个发音不同? Microsoft OLE DB Provider for SQL Server 错误 '80040e14' 第 1 行: ')' 附近有语法错误。 /sell/sell. 急急急,有关sql server存储过程怎么写? 请问关于外国无版权图片网站,上面的使用申明中这段文字应该怎么理解? 盐城购房合同可以上东景山吗? 南京天景山公寓佳福苑二手房均价多少钱一平米? 梦见煤山倒塌的预兆 乐康守护电话手表怎么样 心情很不好,怎么才能快速调整好心情呢? 叉饭,是什么意思? 一个男的用叉子给一个女孩子吃东西那个女孩子没有拒绝,是什么意思 民生银行金普信用卡额度是多少怎么提升额度 余额宝2万一天多少钱? 厦门户口失业金领取条件 厦门失业补助金领取条件及标准2020 有那些女性向后宫动漫? 有什么好看的女性向后宫片? 女性向后宫动漫,美型,2011年以后,求推荐⊙﹏⊙ 微信里的钱怎么免费转到银行卡里呢 1磅是多少厘米 捷达VS5新款最低价格是多少钱?捷达VS5买车价 小学三年级数学上学练优47页瓶子能装多少水 “维也纳工场”的产品的特点是什么以及“维也纳工场”与“德意志制造联盟”相比有什么不同? 武汉市市委书记是副部级吗 武汉市黄陂区委书记曾晟是什么行政级别 市委常委与市长的区别 武汉市纪委书记什么级别 单纯词和单音节词,合成词和多音节词的关系 什么是三类行业? 杂志上说的400呼叫中心有什么用处呢☆ 苏州市有免费的培训中心么? 主要培训空调维修,热水器,洗衣机等一些方面的。 怎样教育小孩子不要偷东西呢? 如何教育孩子不去偷东西呢? 如何教育孩子不要偷东西呢? 怎么教育孩子不能偷东西? 如何教孩子不要偷东西呢? 怎样教育孩子不偷东西? 适合生日发朋友圈的句子古风