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

Posted

篇首语:身体的财富是健康,思想的财富是知识。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 在powerbuilder中使下拉列表框可以和数据关联相关的知识,希望对你有一定的参考价值。

  在从事使用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了

       编辑推荐

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

cha138/Article/program/PB/201311/24638

相关参考

知识大全 可以输入的下拉框

  可以输入的下拉框?很多人相信吧真的可以?真的可以呵呵一起来看看吧  <HTML> <HEAD> <TITLE>NewDocument<

知识大全 根据选择不同的下拉值出现相对应的文本输入框

根据用户选择不同的下拉值出现相应的文本输入框在某些情况下比较实用本文为大家写了个有需求的朋友可以参考下 复制代码代码如下:cha138/Article/program/Java/J

知识大全 js下拉框二级关联菜单效果代码具体实现

这篇文章介绍了js下拉框二级关联菜单效果代码具体实现有需要的朋友可以参考一下 复制代码代码如下: <!DOCTYPEPUBLIC"//WC//DTDXHTMLTransiti

知识大全 如何在Asp.net中实现多彩下拉框

如何在Asp.net中实现多彩下拉框  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  开发背景&n

知识大全 下拉列表

ASP.NETAJAX示例:下拉列表  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  本文的开始简

知识大全 jstl实现在jsp中动态添加下拉列表项

  使用下面这个jsp的前你需要写一个Stu类生成set和get方法  PublicClassStuprivateintid;privateStringname;publicvoidsetId(int

知识大全 下拉框层级绑定

   今天用到一个下拉框绑定要有层级关系显示的也很简单就当第一篇博客!      ///<summary

知识大全 动态提示的下拉框

  <METAcontent=fason阿信name=Author><title>动态提示的下拉框</title><style>acolor:red;t

知识大全 可入文ADD下拉列表

Delphi开发经验技巧:可入文ADD下拉列表  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!&nb

知识大全 JS文本框追加多个下拉框的值的简单实例

JS文本框追加多个下拉框的值的简单实例  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!这篇文章介绍了