我是采用 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,剩下的字符串全部被截断了。
有大侠能指点一二么?不胜感激!
在调用存储过程的时候发生了一个返回值被截断的问题!
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,剩下的字符串全部被截断了。
有大侠能指点一二么?不胜感激!
解决方案 »
- java工程打包后,找不到依赖的jar包。求助如何设置manifest.mf文件
- 求结合多硬件的javaSE解决方案
- 一个模拟火车售票窗口的小程序如何实现?
- 如何在eclipse开发工具下用出这个东西?
- 正则问题
- applet需要java plugin的问题
- 请问用java调用c++写的dll文件,这个dl该如何调试?
- 初学java碰到的几个小问题,请指教
- 请问使用socket编码中读数据时采用InputStream和BufferedReader有什么区别?
- 请问哪位知道Cloudscape下载地址?
- 求!!如何编程开发自定义的可插拔式Java外观??????谢谢
- 懊恼的问题,单步执行与直接执行产生明显差别
建议
@out_var varchar(MAX) OUTPUT (尽管MAX也是8000 但是不会被截断)
或者最好改为
@out_var text OUTPUT
文章来自中国建站:http://www.jz123.cn/text/2216557.html请 shibenjie 注意,我使用的是 数据库为 sqlserver 2000 , text 不能作为参数的类型,请好好学习!给50分奖励!xzy88 :。给50分顶贴奖励!