欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > DOCX文档下载  

    在PB中使下拉列表框可以和数据关联.docx

    • 资源ID:3379448       资源大小:38.06KB        全文页数:4页
    • 资源格式: DOCX        下载积分:6.99金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要6.99金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    在PB中使下拉列表框可以和数据关联.docx

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

    注意事项

    本文(在PB中使下拉列表框可以和数据关联.docx)为本站会员(小飞机)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开