您的位置:首页 > 数据库 > MySQL

JDBC远程调用mysql存储过程错误

2013-07-19 16:15 381 查看
mysql数据库编译安装后,调试程序,使用普通用户通过JDBC连接,远程调用存储过程发现报出java错误java.lang.NullPointerException......空指针异常的错误



这是因为JDBC调用存储过程时需要有show create procudure 权限或是有表mysql.proc的select权限。通过在JDBC连接属性中设置noAccessToProcedureBodies=true(默认false)解决或是授予普通用户相应的权限。该noAccessToProcedureBodies=true的影响:
1. 调用存储过程时,将没有类型检查,设为字符串类型,并且所有的参数设为in类型,但是在调用registerOutParameter时,不抛出异常。
2. 存储过程的查询结果无法使用getXXX(String parameterName)的形式获取,只能通过getXXX(int parameterIndex)的方式获取。最后是通过修改JDBC连接mysql的普通用户的权限后(虽然授以所有权限可以解决,但是不建议)。重新打开页面正常。

本文出自 “老徐的私房菜” 博客,谢绝转载!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: