对powerbuilder实施oracle查询

时间:2019-02-11 04:18:43

标签: oracle powerbuilder

我很难在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中实现查询。

1 个答案:

答案 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 + '%';

请注意,如果返回的行超过一个,则此操作将失败。如果需要多行,则需要使用数据窗口/数据存储控件(或游标,但它们效率很低)。