java - 使用 Spring 中的 HSQLDB 时的 Blob 大小限制

标签 java spring blob hsqldb lob

我正在使用 HSQLDB 进行测试。该数据库是通过 spring 扫描模型创建的。其中一个模型是一条包含附件的消息(从而产生一个 lob)。当尝试保存带有附件的消息时,会导致:org.hsqldb.HsqlException:数据异常:字符串数据,右截断。附件最大只有 4kb。有没有办法从 spring 配置 hsql lob 字段的大小限制?我确定异常是由附件引起的,因为当我评论该行(添加附件)时一切正常。

我的 Spring 配置:

<bean id="transactionManager"
      class="org.springframework.orm.hibernate3.HibernateTransactionManager"
      autowire="autodetect">

    <property name="dataSource">
        <ref local="hsqlDbDataSource"/>
    </property>
</bean>

<bean id="persistenceManager"
      class="org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor"/>

<bean class="org.springframework.beans.factory.config.PropertyOverrideConfigurer">
    <property name="ignoreResourceNotFound">
        <value>true</value>
    </property>
    <property name="location">
        <!--  You may use file:d:/temp/db.properties etc here -->
        <value>classpath:dispatcher.model.db.properties</value>
    </property>
</bean>

<!-- HSQLDB DS -->
<bean id="hsqlDbDataSource" class="org.apache.commons.dbcp.BasicDataSource">
    <property name="driverClassName" value="org.hsqldb.jdbcDriver"/>
    <property name="url" value="jdbc:hsqldb:mem:dispatcher"/>
    <property name="username" value="sa"/>
    <property name="password" value=""/>
    <property name="initialSize" value="20"/>
    <property name="maxActive" value="10"/>
    <property name="poolPreparedStatements" value="true"/>
    <property name="maxOpenPreparedStatements" value="10"/>
</bean>

<!-- Hibernate SessionFactory -->
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource" ref="hsqlDbDataSource"/>

    <property name="packagesToScan">
        <list>
            <value>com.company.project.dispatcher.model.**.*</value>
        </list>
    </property>

    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.HSQLDialect</prop>
            <prop key="hibernate.generate_statistics">true</prop>
            <prop key="hibernate.show_sql">true</prop>
            <prop key="hibernate.cache.use_second_level_cache">true</prop>
            <prop key="hibernate.cache.use_query_cache">true</prop>
            <prop key="hibernate.cache.provider_class">net.sf.ehcache.hibernate.SingletonEhCacheProvider</prop>
            <prop key="hibernate.hbm2ddl.auto">create-drop</prop>
       </props>
    </property>
</bean>

消息模型:

  public class FaxMessage extends Message implements  IFaxMessage {

/** Serial Version UID. */
private static final long serialVersionUID = -558902226L;   

/** Field mapping. */
private Long gatewayMessageId;
/** Field mapping. */
private Integer numberOfPages;
/** Field mapping. */
private Boolean pdfAttached;
/** Field mapping. */
private Byte[] pdfData;
/** Field mapping. */
private String subject;
/** Field mapping. */
private String tiffFileLocation;

...

/**
 * Return the value associated with the column: pdfData.
 * @return A Byte[] object (this.pdfData)
 */
@Basic( optional = true )
@Column( name = "pdf_data"  )
public Byte[] getPdfData() {
    return this.pdfData;

}

/**  
 * Set the value related to the column: pdfData.
 * @param pdfData the pdfData value you wish to set
 */
public void setPdfData(final Byte[] pdfData) {
    this.pdfData = pdfData;
}

最佳答案

字节数组不会自动映射到 Lob。您可能需要将 @Lob 注释添加到该属性。

关于java - 使用 Spring 中的 HSQLDB 时的 Blob 大小限制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11358994/

相关文章:

Java scan.nextLine() 只等待int用户输入的用户输入;不等待字符串用户输入

java - Spring错误: No qualifying bean of type [org. hibernate.SessionFactory]发现依赖关系

azure - SSIS:如何枚举 Azure 存储中的文件并将每个文件加载到 SQL Server 中

javascript - 如何在 React Native 中显示 blob 图像

循环中的java setText

java - 使用基于Java的处理语言读取JSON数据

java - 与多个类(class)一起工作

java - 用于身份验证的 PreInspirationAdvice

java - 可怕的 500 错误试图通过 hibernate 和海报获取 MySql 信息到 thymeleaf :(

php - 当我在 while 循环中从数据库调用 blob 图像时,出现 mysqli_fetch_array() Expectsparameter 1 错误