您的位置:首页 > 编程语言 > Java开发

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

2015-08-18 22:07 609 查看
出现上述异常是在使用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);
		}
	}

                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: