oracle的sql语句where语句中nvl函数的第一个参数可以使用宿主变量不,如where 字段名1=nvl(:va,字段名1) 15

其实我就是为了解决前台传来的某个条件为空值时,对应的那个条件就不要;不为空时,对应的那个条件就用上... 其实我就是为了解决前台传来的某个条件为空值时,对应的那个条件就不要;不为空时,对应的那个条件就用上 展开
 我来答
BuddhaQQ
推荐于2018-03-23 · TA获得超过1762个赞
知道小有建树答主
回答量:860
采纳率:100%
帮助的人:968万
展开全部
看你的问题,字段1=nvl(:va,字段1),是没有问题的

select R.REGION_NAME REGION_NAME, R.REGION_ID HID_ID, SUM(G.BADBILL_FEE) sum_fee from SYS_REGION R, GCI_BADBILL_SUM G where G.city_id = R.REGION_ID and R.SUP_REGION_ID = ? and G.badfee_type_id = nvl(:badfeeType,G.badfee_type_id) and G.badfee_level_id = nvl(:badfeeLevel,G.badfee_level_id) and G.grp_degree_id = nvl(:grpDegree,G.grp_degree_id) 但我在java程序里将宿主变量值传入,出现索引丢失参数错误
检查一下,
1. 检查表sys_region、gci_badbill_sum的索引状态
2. 传入的如果是字符串变量,是否有引号''
3. 如果有必要,贴一下具体的错误,是ORA的还是java的,有的话都贴一下
a939565155
2012-12-16 · 超过43用户采纳过TA的回答
知道小有建树答主
回答量:175
采纳率:0%
帮助的人:91.5万
展开全部
引用楼主:“其实我就是为了解决前台传来的某个条件为空值时,对应的那个条件就不要;不为空时,对应的那个条件就用上”

不用这么麻烦,你在程序中判断传来的变量为空时,把条件放到一个字符串中,如:string str=“ where 1=1 ” ; str=" and 字段="+变量; 然后把这个str追加到你的sql当中不就可以了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
紫面修罗
2012-12-16 · 超过18用户采纳过TA的回答
知道答主
回答量:65
采纳率:0%
帮助的人:20.9万
展开全部
可以
追问
select R.REGION_NAME REGION_NAME, R.REGION_ID HID_ID, SUM(G.BADBILL_FEE) sum_fee from SYS_REGION R, GCI_BADBILL_SUM G where G.city_id = R.REGION_ID and R.SUP_REGION_ID = ? and G.badfee_type_id = nvl(:badfeeType,G.badfee_type_id) and G.badfee_level_id = nvl(:badfeeLevel,G.badfee_level_id) and G.grp_degree_id = nvl(:grpDegree,G.grp_degree_id) 但我在java程序里将宿主变量值传入,出现索引丢失参数错误
追答
你可以写个存储过程,给存储过程传参数.
JAVA我不了解.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式