注册 登录
编程论坛 PowerBuilder

关于dddw子数据窗口过滤的问题

daring 发布于 2006-07-12 14:08, 2582 次点击

我在一个数据窗口中用了一个DDDW子数据窗口,当焦点在这个子数据窗口中时,我想实现边输入,边过滤数据

4 回复
#2
fgypblt2006-07-12 17:53
将datawindow相关联不行吗.

边过滤数据?
#3
潇洒老乌龟2006-07-13 11:09
数据窗口中的增量查询功能

  问:请问在PB的数据窗口中怎样实现某一列的增量查询功能,就是说在单行编辑器控件中每输入一个字符,数据窗口能找到这一列值左边部分与单行编辑器中内容相等的行,并加亮显示。例如数据窗口是按整型字段“ID”升序排列的,用户在单行编辑器中输入1,则数据窗口滚动到ID字段第一位为“1”的第一行并加亮显示;再在1后输入0,则数据窗口滚动到ID字段前两位为“10”的第一行,依次类推。
  答:增量查询功能实现的关键有两点,一是单行编辑器能实时响应键盘的输入,捕捉每一个按键,获得其中的文本;二是数据窗口的模糊查询功能,即能够找到列ID左边文本与单行编辑器文本相等的行,这可以用“like”来实现。下面给出具体方法:
  1、定义单行编辑器的用户事件ue_enchange,事件的ID为:pbm_enchange。这个事件能响应键盘的输入。
  2、在单行编辑器的ue_enchange事件中编写如下脚本:
  long ll_found_row
  string ls_find
  ls_find = ″string(id) like ″ + ″′″ + this.text + ″%′″ //查找条件(左部分与单行编辑器文本相等)
  ll_found_row = dw_name.Find(ls_find, 1, dw_name.RowCount()) //查找符合条件的行
  if ll_found_row <= 0 then return
  dw_name.ScrollToRow(ll_found_row) //滚动到相匹配的行
  dw_name.SelectRow(0 , false)
  dw_name.SelectRow(ll_found_row , true) //将匹配行加亮显示

#4
daring2006-07-13 14:03

首先谢谢大家对我问题的关注,尤其是潇洒版主,不过你说的这种方法实现不了我想要的功能,在我的数据窗口控件关联的那个数据窗口对象里面的一个列名为YD_ADD的列是一个DDDW型的子数据窗口,当我的数据窗口控件发生itemchanged事件的时候,并且焦点在这个列名为YD_ADD上,这个子数据窗口里的数据要显示出来,当用户输入时,能自动过滤里面的数据

#5
fgypblt2006-07-13 15:35
filter
1