jtds调用存储过程返回值(大侠速来,急)

deadncut 2009-06-06 12:11:45
我是采用 jtds-1.2.2 做的数据库连接(数据库为 sqlserver 2000)
在调用存储过程的时候发生了一个返回值被截断的问题!
java代码如下:
cstmt = _connection.prepareCall("EXECUTE GetPropStr ?,?,?");
cstmt.setString(1, condition.getUserid());
cstmt.setString(2, condition.getLeibieID());
cstmt.registerOutParameter(3, java.sql.Types.VARCHAR);
cstmt.execute();
System.out.pintln(cstmt.getString(3));

存储过程定义如下:
CREATE PROCEDURE GetPropStr
@UserId varchar(10),
@LeibieId varchar(12),
@out_var varchar(8000) OUTPUT

在存储过程中, print @out_var ,打出来的串是正确的,长度为 6000 多的字符串。
但是 System.out.pintln(cstmt.getString(3)); 这里打出来的长度为 4000,剩下的字符串全部被截断了。
有大侠能指点一二么?不胜感激!

...全文
120 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
shibenjie 2009-06-06
  • 打赏
  • 举报
回复
楼主所说大概长度超过了
建议
@out_var varchar(MAX) OUTPUT (尽管MAX也是8000 但是不会被截断)
或者最好改为
@out_var text OUTPUT
网络科技 2009-06-06
  • 打赏
  • 举报
回复
返回值被截断要么长度超过了,要么类型不匹配,自己再认真排查下吧
deadncut 2009-06-06
  • 打赏
  • 举报
回复
SQL Server的开发人员很幸运,他们将会拨开乌云见蓝天。SQL Server 2005引入了一系列新的被称为MAX的数据类型。这是VARCHAR,NVARCHAR和VARBINARY类型的扩展,这几种类型以前被限制在8000字节以下。MAX可以容纳高达2GB的数据,与TEXT和IMAGE一样——并且完全兼容所有的SQL Server内置的字符串函数。
文章来自中国建站:http://www.jz123.cn/text/2216557.html

请 shibenjie 注意,我使用的是 数据库为 sqlserver 2000 , text 不能作为参数的类型,请好好学习!给50分奖励!

xzy88 :。。。。给50分顶贴奖励!
注意,以下使用数据库为sql2000,驱动jtds1.2.2 一、调用存储过程(无结果集返回) Connection connection = ConnectionHelper.getConnection(); CallableStatement callableStatement = connection.prepareCall("{ call procedureName(?,?) }"); callableStatement.setString(1, "xxxxxxxx"); callableStatement.setString(2, "xxxxxxxx"); callableStatement.execute(); //获得sql的消息并输出,这个估计很多人都需要 SQLWarning sqlWarning = callableStatement.getWarnings(); while (sqlWarning != null) { System.out.println("sqlWarning.getErrorCode() = " + sqlWarning.getErrorCode()); System.out.println("sqlWarning.getSQLState() = " + sqlWarning.getSQLState()); System.out.println("sqlWarning.getMessage() = " + sqlWarning.getMessage()); sqlWarning = sqlWarning.getNextWarning(); } //close ConnectionHelper.closeConnection(callableStatement, connection); 二、调用存储过程,返回sql类型数据(非记录集) Connection connection = ConnectionHelper.getConnection(); CallableStatement callableStatement = connection.prepareCall("{ call procedureName(?,?,?) }"); callableStatement.setString(1, "xxxxxxxx"); callableStatement.setString(2, "xxxxxxxx"); //重点是这句1 callableStatement.registerOutParameter(3, Types.INTEGER); callableStatement.execute(); //取返回结果,重点是这句2 //int rsCount = callableStatement.getInt(3); //close ConnectionHelper.closeConnection(callableStatement, connection); 三、重点来了,返回记录集,多记录集 注意,不需要注册返回结果参数,只需要在sql中select出结果即可 例如:select * from tableName 即可得到返回结果 Connection connection = ConnectionHelper.getConnection(); CallableStatement callableStatement = connection.prepareCall("{ call procedureName(?) }"); //此处参数与结果集返回没有关系 callableStatement.setString(1, "xxxxxxxx"); callableStatement.execute(); ResultSet resultSet = callableStatement.getResultSet(); //以上两个语句,可以使用ResultSet resultSet = callableStatement.executeQuery();替代 //多结果返回 ResultSet resultSet2; if (callableStatement.getMoreResults()) { resultSet2 = callableStatement.getResultSet(); while (resultSet2.next()) { } } //close ConnectionHelper.closeConnection(callableStatement, connection); 提示:多结果返回可以使用如下代码(以上主要让大家明白,单一结果和多结果的区别): Boolean hasMoreResult = true; while (hasMoreResult) { ResultSet resultSet = callableStatement.getResultSet(); while (resultSet.next()) { } hasMoreResult = callableStatement.getMoreResults(); }

62,630

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧