java中的preparecall,关于prepareCall的sql语句中(?)的问题

源自:2-4 JDBC存储过程之调用带输出参数的存储过程

关于prepareCall的sql语句中(?)的问题

最开始打印全部信息,没有过滤器的那条代码,()中是没有?的。

第一条sql语句:

CallableStatement cs = conn.prepareCall("call first_db_select_nofilter()");

然后是需要传入一个值,根据值来进行查询,这里为(?),所以我把?理解为传入的参数。

第二条sql语句:

CallableStatement cs = conn.prepareCall("call first_select_filter(?)");

最后是一个传出记录的条数,只有输出没有输入,为什么也是(?)呢,求大神解答(?)中?的作用。

第三条sql语句:

CallableStatement cs = conn.prepareCall("call first_select_count(?)");

最后一条如果sql语句中不加?会报出数组下标越界的异常,这是为什么呢?

这是报出的异常:

java.lang.ArrayIndexOutOfBoundsException: 0

求大神解答疑惑。

提问者:是窗边的小豆豆啊

2018-11-28 17:21

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值