与Spring一起使用时,Hibernate会向表中插入空值

时间:2011-04-27 18:37:11

标签: java spring hibernate

我试图在Spring中使用hibernate并使用HSQL DB。我无法将我的对象持久化到数据库,因为Hibernate不从对象中获取值,而是在生成的Insert语句中使用null值。我正试图调试这个问题一段时间,并且已经没有想法了。非常感谢任何有关该问题的帮助。

以下是我的代码段。

应用程序上下文(applicationContext.xml):我正在上下文中配置我的数据源,会话工厂,DAO和事务管理器。

<context:component-scan base-package="com.wb.services.fileservice" />

    <tx:annotation-driven />

<jdbc:embedded-database id="dataSource">
    <jdbc:script location="classpath:com/wb/services/testdb/schema.sql" />
    <jdbc:script location="classpath:com/wb/services/testdb/test-data.sql" />
</jdbc:embedded-database>

<bean id="sessionFactory"
    class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="mappingResources">
        <list>
            <value>/com/wb/services/fileservice/file.hbm.xml</value>
        </list>
    </property>
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.HSQLDialect</prop>
            <prop key="hibernate.cache.provider_class">org.hibernate.cache.NoCacheProvider</prop>
            <prop key="hibernate.show_sql">true</prop>
        </props>
    </property>
</bean>

<bean id="fileServiceDAO" class="com.wb.services.fileservice.FileServiceDAO">
    <constructor-arg ref="sessionFactory" />
</bean>

<bean id="transactionManager"
    class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory" ref="sessionFactory" />
</bean>

我的Hibernate Mapping文件(file.hbm.xml):

<class name="com.wb.services.fileservicemodel.FilePrintHibernate" table="T_FILES">

<id name="fileID" column="File_ID" type="int">
        <generator class="native"/>
    </id>
    <property name="name" column="Name"/>
    <property name="text" column="Text"/>
</class>

需要持久化的瞬态类(FilePrintHibernate):

public class FilePrintHibernate implements Serializable {

    private int fileID;
    private String name;
    private String text;

// Skipping getters and setters for the above.

}

将对象持久化到DB表的DAO类。

@Repository

@Transactional

public class FileServiceDAO {

    private SessionFactory sessionFactory;


    public FileServiceDAO() {
    }

    public FileServiceDAO(SessionFactory sessionFactory) {
        this.sessionFactory = sessionFactory;
    }

    public SessionFactory getSessionFactory() {
        return sessionFactory;
    }

    public Session getCurrentSession() {
        return sessionFactory.getCurrentSession();
    }

    @Transactional(readOnly = false, propagation=Propagation.REQUIRED)
    public void findByCreditCard(String filename) {

        FilePrintHibernate filePrintHibernate = new FilePrintHibernate();
        filePrintHibernate.setFileID(2);
        filePrintHibernate.setName("Manual");
        filePrintHibernate.setText("Hibernate Test Example");

        getCurrentSession().save(filePrintHibernate);
        getCurrentSession().flush();
    }
}

当app运行并且DAO类(上面的代码文件4)试图保持FilePrintHibernate对象时,我收到的insert语句是:insert into T_FILES (File_ID, Name, Text) values (null, ?, ?)。请注意它尝试插入的值。而不是我设置的值(2,“手动”,“休眠测试示例”)。

你可以告诉我上面的错误。任何上述帮助都非常感谢。

此致

虚无

1 个答案:

答案 0 :(得分:1)

我相信这是因为你的id字段有一个本机生成器集,因此hibernate决定将它的选择留给数据库。尝试手动运行查询并查看将设置的ID。如果它是正确的,请在休眠中提交一个错误(在升级到最新版本之后)。