oracle根据参数条件,怎么用参数控制执行不同的sql语句(答案)

当前位置:我的异常网» Oracle技术 » 怎么用参数控制执行不同的sql语句(答案)

怎么用参数控制执行不同的sql语句(答案)

www.myexceptions.net  网友分享于:2013-02-02  浏览:41次

如何用参数控制执行不同的sql语句(在线等答案)

做一个finereport报表,从页面传值到报表,页面可以选择部分客户,也可以选全部客户,URL传值时按照这两种情况传值,一种传客户codeID,一种不传客户codeID,报表的sql语句能否根据两种情况,分别执行不同的语句呢? 请大侠指教。

sql:

SELECT c.scode, c.sname, ttt.*

FROM (SELECT tt.*

FROM ( ( SELECT MAX (amount) AS maxAmount, NCLIENTID

FROM ( SELECT b.NCLIENTID,

SUM (A.MAMOUNT) AS amount,

A.DTEXECUTE

FROM SETT_TRANSACCOUNTDETAIL a,

SETT_ACCOUNT b

WHERE A.NTRANSACCOUNTID = B.ID

AND A.NSTATUSID = 3

AND A.NOFFICEID = 1

AND A.NCURRENCYID = 1

AND A.NTRANSACTIONTYPEID IN

(1, 12, 15)

AND A.NTRANSDIRECTION = 2

AND A.DTEXECUTE BETWEEN TO_DATE (

'2011-01-01',

'yyyy-mm-dd'

)

AND TO_DATE (

'2011-05-01',

'yyyy-mm-dd'

)

GROUP BY b.NCLIENTID, A.DTEXECUTE

ORDER BY b.NCLIENTID, A.DTEXECUTE)

GROUP BY NCLIENTID) t

JOIN

( SELECT b.NCLIENTID,

SUM (A.MAMOUNT) AS amount,

A.DTEXECUTE

FROM SETT_TRANSACCOUNTDETAIL a, SETT_ACCOUNT b

WHERE

A.NTRANSACCOUNTID = B.ID

AND A.NSTATUSID = 3

AND A.NOFFICEID = 1

AND A.NCURRENCYID = 1

AND A.NTRANSACTIONTYPEID IN (1, 12, 15)

AND A.NTRANSDIRECTION = 2

AND A.DTEXECUTE BETWEEN TO_DATE (

'2011-01-01',

'yyyy-mm-dd'

)

AND TO_DATE (

'2011-05-01',

'yyyy-mm-dd'

)

GROUP BY b.NCLIENTID, A.DTEXECUTE

ORDER BY b.NCLIENTID, A.DTEXECUTE) tt

ON t.maxAmount = tt.amount AND t.NCLIENTID = tt.NCLIENTID))

ttt,

client c

WHERE ttt.NCLIENTID = c.id

----只需看下面几行sql

文章评论

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值