我有 java 代码,它应该访问 SQL 函数的返回值。SQL 函数返回四个具有 VARCHAR 类型的值。下面给出了java代码
ResultSet rs = null;
CallableStatement stmt = null;
List<TestObj> objList= new ArrayList<TestObj>();
try
{
stmt = con.prepareCall( "{? = call TEST_FUNCTION(?,?) }");
int count = 0;
stmt.registerOutParameter( ++count, Types.VARCHAR );
stmt.setString( ++count, "A");
stmt.setString( ++count, "B");
stmt.execute();
rs = stmt.getResultSet();
while( rs.next() )
{
TestObj obj= new TestObj ();
obj.setA( rs.getString( "TEST1" ) );
obj.setB( rs.getString( "TEST2" ) );
obj.setC( rs.getString( "TEST3" ) );
obj.setD( rs.getString( "TEST4" ) );
objList.add( obj);
}
}
catch( SQLException e )
{
e.printStackTrace();
}
finally
{
rs.close();
stmt.close();
}
运行时,它在“rs.next()”处给了我一个空点异常。谁能告诉我如何访问函数的返回值。
注意:将值传递给函数并执行查询工作正常,没有任何异常( stmt.execute() 运行没有任何异常)