struts+spring+hibernate无法插入数据库数据的问题
2013-03-05 23:12
549 查看
用spring,hibernate发现无法往数据库里插入数据。其他一切正常,既不报exception,控制台sql又打出来了。试了无数种方法仍不能解决,郁闷。。。。。。。。
忽然灵机一动,只用hibernate的话,添加或修改数据需要commit一下,会不会与此有关?
想到就试,在addOrUpdate后,加一句super.getSession().beginTransaction().commit(); OK,搞定。
回过头来查原因,原来在spring的配置文件中加载hibernate的配置是这样的:
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation"
value="classpath:hibernate.cfg.xml">
</property>
</bean>
换句话说,是使用了hibernate本身的配置文件,所以特性呈现为hibernate而不是spring。
把该配置文件改为
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref local="dataSource"/>
</property>
<property name="mappingResources">
<list>
<value>xxx.hbm.xml</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.generate_statistics">true</prop>
<prop key="hibernate.query.factory_class">org.hibernate.hql.classic.ClassicQueryTranslatorFactory</prop>
</props>
</property>
</bean>
后,就不需要手动commit了。
或在不改变原有配置文件的基础上,添加自动提交
<property name="connection.autocommit">true</property> 也可以
忽然灵机一动,只用hibernate的话,添加或修改数据需要commit一下,会不会与此有关?
想到就试,在addOrUpdate后,加一句super.getSession().beginTransaction().commit(); OK,搞定。
回过头来查原因,原来在spring的配置文件中加载hibernate的配置是这样的:
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation"
value="classpath:hibernate.cfg.xml">
</property>
</bean>
换句话说,是使用了hibernate本身的配置文件,所以特性呈现为hibernate而不是spring。
把该配置文件改为
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref local="dataSource"/>
</property>
<property name="mappingResources">
<list>
<value>xxx.hbm.xml</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.generate_statistics">true</prop>
<prop key="hibernate.query.factory_class">org.hibernate.hql.classic.ClassicQueryTranslatorFactory</prop>
</props>
</property>
</bean>
后,就不需要手动commit了。
或在不改变原有配置文件的基础上,添加自动提交
<property name="connection.autocommit">true</property> 也可以
相关文章推荐
- 【转载】struts+spring+hibernate无法插入数据库数据的问题
- Spring、Hibernate 数据不能插入到数据库问题解决
- Spring、Hibernate 数据不能插入到数据库问题解决
- hibernate调用sessionFactory.getCurrentSession().save(entity);数据无法插入到数据库
- 关于在执行hibernate3.0的save方法后数据无法添加到数据库的问题
- MyEclipse生成的Spring+Hibernate无法保存数据问题的解决方法
- Hibernate+Spring:控制台不报错SQL打印正常但是无法写入数据库问题
- 用maven整合struts+spring+hibernate之二 数据库生成和测试数据
- 用Maven整合SpringMVC+Spring+Hibernate 框架,实现简单的插入数据库数据功能(二)
- 解决:hibernate查询过多时与数据库连接断开或无法再查询到数据问题。
- springmvc+hibernate+workbench网站访问数据库中文无法显示问题
- 用Maven整合SpringMVC+Spring+Hibernate 框架,实现简单的插入数据库数据功能
- struts向数据库插入中文数据乱码问题
- 使用DOS命令无法插入中文数据到数据库的问题
- 用Maven整合SpringMVC+Spring+Hibernate 框架,实现简单的插入数据库数据功能(二)
- spring+hibernate-struts数据写入SQL SERVER 2000数据库回滚
- hibernate 实行原生sql insert数据无法插入到数据库
- 用Maven整合SpringMVC+Spring+Hibernate 框架,实现简单的插入数据库数据功能
- spring+hibernate 插入数据时控制台打印出sql语句,但是数据库中并没有数据解决方法
- 用Maven整合SpringMVC+Spring+Hibernate 框架,实现简单的插入数据库数据功能