【求助】pb 数据窗口中某一字段的dropdown内容筛选
例如:数据窗口中选择了“所属的乡镇”的值,“所属村”字段用的dropdown,我需要在所属村这个字段的下拉框中指显示刚刚选择的镇中的村...
例如:数据窗口中选择了“所属的乡镇”的值,“所属村”字段用的dropdown,我需要在所属村这个字段的下拉框中指显示刚刚选择的镇中的村
展开
展开全部
方法:假设数据窗口为dw_1,itemchanged事件中:
if dwo.name='镇字段名' then
datawindowchild ld_child
dw_1.getchild('村字段',ld_child)
ld_child.settransobject(sqlca)
ld_child.retrieve(dwo,data)
end if
注明;dropdown dw中要设置检索参数,乡镇要有一定的关联,本人用上级分类来做区分。具体问题还要你具体对待!
if dwo.name='镇字段名' then
datawindowchild ld_child
dw_1.getchild('村字段',ld_child)
ld_child.settransobject(sqlca)
ld_child.retrieve(dwo,data)
end if
注明;dropdown dw中要设置检索参数,乡镇要有一定的关联,本人用上级分类来做区分。具体问题还要你具体对待!
更多追问追答
追问
我要输的这个数据窗口是“村民基本信息表”,这个表里有两个字段“z_bh”、“c_bh”,这个两个字段都是用的dropdown属性,“z_bh”dropdown用的数据窗口两个字段是"z_bh","z_mc",这连个字段来自“镇基本信息表”;"c_bh”dropdown用的数据窗口两个字段是"c_bh","c_mc",这连个字段来自“村基本信息表”,“村基本信息表”里头有“z_bh"这个字段。这种情况在这里我要怎么建关联呢?怎样才能完全实现效果。
追答
“z_bh”dropdow里面的现实属性是z_mc,数据值是z_bh。c_bh”dropdown数据窗口里面的sql的语法:select c_bh,c_mc ,z_bh from 表明称 where z_bh=:bh 其中bh为定义的检索参数。然后就是itemchanged事件中:
if dwo.name='z_bh' then
datawindowchild ld_child
dw_1.getchild('c_bh',ld_child)
ld_child.settransobject(sqlca)
ld_child.retrieve(dwo.data)
end if
应该就可以了
展开全部
可以对于下拉数据窗口进行过滤,或者对于下拉数据窗口进行带参数的查询。
假设所属村的字段名字是country_id
那么获取下拉的代码:
可以写在数据窗口的itemchanged事件中,不过我觉得写在点击事件中也可以。
这样可以根据每行来判断这一行的乡镇的值了。
写在clicked事件代码如下:
if dwo.name = 'country_id' then
if row <= 0 then return
string ls_village
ls_village = this.object.村镇字段[row]
datawindowchild l_child
dw_1.getchild('country_id', l_child)
l_child.settransobject(sqlca)
l_child.retrieve()
l_child.setfilter("村镇字段 = '" +ls_village+ "'")
l_child.filter()
end if
或者在下拉的数据窗口中设置查询参数,每次l_child.retrieve(ls_village)来控制也可以
假设所属村的字段名字是country_id
那么获取下拉的代码:
可以写在数据窗口的itemchanged事件中,不过我觉得写在点击事件中也可以。
这样可以根据每行来判断这一行的乡镇的值了。
写在clicked事件代码如下:
if dwo.name = 'country_id' then
if row <= 0 then return
string ls_village
ls_village = this.object.村镇字段[row]
datawindowchild l_child
dw_1.getchild('country_id', l_child)
l_child.settransobject(sqlca)
l_child.retrieve()
l_child.setfilter("村镇字段 = '" +ls_village+ "'")
l_child.filter()
end if
或者在下拉的数据窗口中设置查询参数,每次l_child.retrieve(ls_village)来控制也可以
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
学习了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |