我在实施Oracle查询到PowerBuilder的难度。我有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的困难。
既然你不使用的是一个窗口控件说我会假设你不是。有了这样说那么这必须有一些方法内一块嵌入式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 + '%';
请注意,这将失败,如果超过则返回单行。如果你需要多行你需要使用的DataWindow /数据存储控制(或游标,但他们是非常低效的)。