我正在开发一个由tomcat上的hibernate支持的JPA应用程序。我们也在使用Spring和AOP。该数据库是DB2 9.7社区版。我们使用Spring JNDI查找从tomcat中检索数据源。
这是与Liferay门户捆绑在一起的tomcat 6.0.26。更新tomcat不是一种选择,因为我们在将Liferay升级到更新版本/ bundle时遇到了问题。
在我们的测试用例中,持久化运行良好,但是使用tomcat时我们会遇到以下异常。该应用程序运行良好,直到我想存储附件。
Caused by: java.lang.AbstractMethodError: org.apache.tomcat.dbcp.dbcp.DelegatingPreparedStatement.setBinaryStream(ILjava/io/InputStream;J)V
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.hibernate.engine.jdbc.internal.proxy.AbstractStatementProxyHandler.continueInvocation(AbstractStatementProxyHandler.java:122)
at org.hibernate.engine.jdbc.internal.proxy.AbstractProxyHandler.invoke(AbstractProxyHandler.java:81)
at $Proxy432.setBinaryStream(Unknown Source)
at org.hibernate.type.descriptor.sql.BlobTypeDescriptor$4$1.doBind(BlobTypeDescriptor.java:163)
查看其他问题Why do I get java.lang.AbstractMethodError when trying to load a blob in the db?问题似乎是使用了jdbc3驱动程序而不是jdbc4驱动程序。但是我确保我们有正确的DB2驱动程序版本“db2jcc4.jar 4.14.113”。相同的驱动程序适用于我们的测试用例。
当在别处搜索时,问题是setBinaryStream是用long而不是int调用的,但是由于我没有直接调用任何东西,所以我无法改变它。
有问题的实体:
@Table( name = "ATTACHMENT")
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(namespace = "somenamespace", name = "Attachment")
public class Attachment implements Serializable {
private static final long serialVersionUID = 1L;
/**
*/
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "ID", nullable = false)
@Basic(fetch = FetchType.EAGER)
@Id
@XmlElement
Integer id;
/**
*/
@Column(name = "ATTACHMENT", nullable = false)
@Basic(fetch = FetchType.EAGER)
@Lob
@XmlElement
byte[] attachment;
.. getters/setters and other properties
}
可以做些什么来规避问题,以便像测试用例一样保存实体?
更新:可能不是db驱动程序本身,但tomcat连接池不符合JDBC4。 Tomcat 6 documentation表示“DBCP 1.3提供对JDBC 3.0的支持。”在查看tomcat-dbcp vs commons-dbcp时,与普通dbcp交换似乎不是一个好主意。
答案 0 :(得分:1)
过了一会儿,我找到了解决方案。
我下载了tomcat 7并复制了tomcat-dbcp。
tomcat-dbcp 7包含dbcp 1.4并提供JDBC 4.0支持。