出现上述异常是在使用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);
}
}