实施Oracle查询到的PowerBuilder

问题描述 投票:0回答:1

我在实施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的困难。

oracle powerbuilder
1个回答
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 + '%';

请注意,这将失败,如果超过则返回单行。如果你需要多行你需要使用的DataWindow /数据存储控制(或游标,但他们是非常低效的)。

© www.soinside.com 2019 - 2024. All rights reserved.