java.lang.AbstractMethodError: com.mysql.jdbc.PreparedStatement.setCharacterStream(ILjava/io/Reader;

出现上述异常是在使用MySQL进行大文本数据的读写时,使用PreparedStatement中的

setCharacterStream(int parameterIndex,
                      Reader reader,
                      int length)
方法的时候产生的。查看API可以得到该方法还有另一种实现

void setCharacterStream(int parameterIndex,
                      Reader reader,
                      long length)
不同之处在于第三个参数类型上。第二种实现是在JDK1.6之后才有的前者是在JDK1.2有的,虽然在建工程并使用第三个参数为long类型的setCharacterStream时候并没有报错,然而在进行测试的时候却总是通不过,出现

java.lang.AbstractMethodError: com.mysql.jdbc.PreparedStatement.setCharacterStream(ILjava/io/Reader;

异常,百思不得解……


在这种使用合法环境符合要求的情况下,尝试将第三个参数强制转换为int类型,测试顺利通过


代码如下:

	@Test
	public void insert(){
		Connection conn = null;
		java.sql.PreparedStatement ps = null;
		ResultSet rs = null;
		
		try {
			conn = JdbcUtils.getConnection();
			String sql = "INSERT INTO testclob(id,textfile) VALUES(?,?)";
			ps = conn.prepareStatement(sql);
			ps.setString(1, "1");
			
			File file = new File("src/text.txt");
			FileReader reader = new FileReader(file);
			ps.setCharacterStream(2, reader, (int)file.length());

			int num = ps.executeUpdate();
			if(num > 0)
				System.out.println("success");
		} catch (Exception e) {
			e.printStackTrace();
		}finally{
			JdbcUtils.release(rs, ps, conn);
		}
	}






                
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值