网站建设| 数据库类| 图形图象| 程序设计| 现代办公| 操作系统| 考试认证| 网络技术| 软件工程| 电脑相关| 文学作品
网站开发| 网页制作| 操作系统| 图象图形| 考试认证| 数据库类| 程序设计| 硬件技术| 现代办公| 网络技术| 笑话频道
 
您的位置: 电脑书库首页-> 电脑文摘-> 数据库类-> PowerBuilder-> 在powerbuilder中使下拉列表框可以和数据关联

在powerbuilder中使下拉列表框可以和数据关联
作者:佚名 来源:InterNet 加入时间:2005-1-31
相关文章
  • 浅析PowerBuilder下动态SQL语句
  • 在powerbuilder中向Excel传递数据
  • 在PowerBuilder中调用ChooseColor函数
  • PowerBuilder连接Sybase SQL Server的注意事项
  • PowerBuilder编程技巧四则
  • 用Powerbuilder开发WEB数据库
  • 利用POWERBUILDER开发数据库的WEB查询
  • PowerBuilder中实现数据窗口打印预览通用方法
  • 怎样用PowerBuilder开发WEB应用
  • PowerBuilder制作IE风格的图标按钮
  • 相关书籍:
  • PowerBuilder系列讲座
  • PowerBuilder 6.0用户参考手册
  • PowerBuilder 7.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了.

    [文章录入员:nancy]

    相关文章
  • 浅析PowerBuilder下动态SQL语句
  • 在powerbuilder中向Excel传递数据
  • 在PowerBuilder中调用ChooseColor函数
  • PowerBuilder连接Sybase SQL Server的注意事项
  • PowerBuilder编程技巧四则
  • 用Powerbuilder开发WEB数据库
  • 利用POWERBUILDER开发数据库的WEB查询
  • PowerBuilder中实现数据窗口打印预览通用方法
  • 怎样用PowerBuilder开发WEB应用
  • PowerBuilder制作IE风格的图标按钮
  • 相关书籍:
  • PowerBuilder系列讲座
  • PowerBuilder 6.0用户参考手册
  • PowerBuilder 7.0
  • 本站推荐内容

    近期主机类热搜关键词:
    美国服务器 美国服务器租用 海外服务器租用 国外服务器租用

    PowerBuilder
    ACCESS
    MS SQL
    MySQL
    Oracle
    Foxpro
    PowerBuilder
    Sybase
    其它
    电脑教程阅读排行
    ·浅析PowerBuilder下动...
    ·PowerBuilder连接Sy...
    ·用Powerbuilder开发W...
    ·在powerbuilder中向E...
    ·PB通过OLEObject使用W...
    ·PB中读取地磅BCD解码
    ·在PowerBuilder中操作...
    ·PB动态报表格式自由定义的实现
    ·PB开发Sybase数据库应用技...
    ·如何在PB中制作特殊形状数据窗口...