我很难在Powerbuilder中实现Oracle查询。我有3个singeline编辑名称是: 1. sle_merk 2. sle_tipe 3. sle_jns
我有oracle查询
select b.nm_merk
, c.keterangan
, c.tipe
, b.keterangan
, c.usrid
, c.otr
, c.dupd
, c.dotr
, c.status
from tipe_kend c
left
outer
join jns_kendaraan b
on c.kd_jenis = b.kd_jenis
left
outer
join merk_kend b
on c.kd_merk = b.kd_merk
where b.kd_jenis like '%%'
AND b.kd_merk like '%%'
AND c.tipe like '%%'
我想要的是,如果所有的singeline编辑都为null,则显示数据,但是当其中一个singeline编辑被填充时,该数据出现在%singelineedit%之类的数据中。我很难在Powerbuilder中实现查询。
答案 0 :(得分:0)
由于您没有说您正在使用数据窗口控件,所以我认为您没有。话虽这么说,然后这肯定是某种方法中的一段嵌入式SQL。因此,您需要为检索中的每个列声明变量。您还需要变量来保存SLE控件的内容。
您最终会得到这样的东西:
string ls_nm // make sure datatypes are correct
string ls_sle1, ls_sle2, ls_sle3
// get values of the sle controls
ls_sle1 = sle_merk.text
IF IsNull(ls_sle1) THEN ls_sle1 = ''
ls_sle2 = sle_tipe.text
IF IsNull(ls_sle2) THEN ls_sle2 = ''
ls_sle3 = sle_jns.text
IF IsNull(ls_sle3) THEN ls_sle3 = ''
select b.nm_merk, ...
INTO :ls_nm, ...
from tipe_kend c
left outer join ns_kendaraan b on c.kd_jenis = b.kd_jenis
left outer join merk_kend b on c.kd_merk = b.kd_merk
where b.kd_jenis like '%' + ls_sle1 + '%'
AND b.kd_merk like '%' + ls_sle2 + '%'
AND c.tipe like '% + ls_sle3 + '%';
请注意,如果返回的行超过一个,则此操作将失败。如果需要多行,则需要使用数据窗口/数据存储控件(或游标,但它们效率很低)。