使用spring-data-jpa保存数据,提交成功,但是数据库没有保存到数据,但是显然是提交了的

itwarcraft 发布于 2013/03/16 09:58
阅读 23K+
收藏 1

使用spring-data-jpa,用的是hibernate的Jpa实现,测试保存没有报错,但是数据库没有存上,原因应该是事务最终没有提交,感觉上是这个样子的。但是 不知道怎么配置。请解答。
数据库:postgresql 8.4

spring配置文件applicationContext.xml:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
	xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
	xmlns:jpa="http://www.springframework.org/schema/data/jpa"
	xmlns:repository="http://www.springframework.org/schema/data/repository"
	xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
		http://www.springframework.org/schema/context
		http://www.springframework.org/schema/context/spring-context-3.0.xsd
		http://www.springframework.org/schema/aop
        http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
		http://www.springframework.org/schema/tx
        http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
        http://www.springframework.org/schema/data/jpa
       http://www.springframework.org/schema/data/jpa/spring-jpa-1.0.xsd
       http://www.springframework.org/schema/data/repository
       http://www.springframework.org/schema/data/repository/spring-repository-1.0.xsd">

	<aop:aspectj-autoproxy proxy-target-class="true"/>

	<context:component-scan base-package="test">
		<context:include-filter type="annotation"
			expression="org.aspectj.lang.annotation.Aspect" />
		<context:exclude-filter type="annotation"
			expression="org.springframework.stereotype.Controller" />
	</context:component-scan>

	<jpa:repositories base-package="test.repository"
		entity-manager-factory-ref="entityManagerFactory"
		transaction-manager-ref="transactionManager" />

	<context:annotation-config />

	<context:property-placeholder location="classpath:jdbc.properties" />

	<bean id="dataSource" class="com.jolbox.bonecp.BoneCPDataSource"
		destroy-method="close">
		<property name="driverClass" value="${jdbc.driverClass}" />
		<property name="jdbcUrl" value="${jdbc.jdbcUrl}" />
		<property name="username" value="${jdbc.username}" />
		<property name="password" value="${jdbc.password}" />
		<property name="defaultAutoCommit" value="false" />
	</bean>

	<bean id="entityManagerFactory"
		class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
		<property name="dataSource" ref="dataSource" />
		<property name="jpaVendorAdapter" ref="hibernateJpaVendorAdapter"/>
		<property name="packagesToScan" value="com.palmer.permission.domain"/>
		<property name="persistenceXmlLocation" value="classpath:persistence.xml" />
	</bean>

	<bean id="hibernateJpaVendorAdapter" class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">  
	    <property name="databasePlatform" value="${hibernate.dialect}" />  
	</bean> 

	<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
		<property name="entityManagerFactory" ref="entityManagerFactory" />
	</bean>
	<!-- 使用annotation定义事务 -->
	<tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true" />

</beans>
JPA配置文件 persistence.xml
<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence" version="2.0"> 
 
 	<persistence-unit name="palmer.unit" transaction-type="RESOURCE_LOCAL"> 
        <provider>org.hibernate.ejb.HibernatePersistence</provider>
        <class>test.domain.User</class>
        <class>test.domain.Role</class>
        <exclude-unlisted-classes>true</exclude-unlisted-classes>
        
        <properties>
            <property name="generateDdl" value="true" />
            <property name="databasePlatform" value="${hibernate.dialect}" />
            <property name="hbm2ddl.auto" value="${hibernate.hbm2ddl.auto}"/>
            <property name="hibernate.show_sql" value="${hibernate.show_sql}"/>
            <property name="hibernate.format_sql" value="${hibernate.format_sql}"/>
            <!-- <property name="hibernate.connection.isolation" value="8"/> -->
            <property name="hibernate.current_session_context_class" value="thread"/>
        </properties>
    </persistence-unit>
</persistence>
UserRepository接口类:
public interface UserRepository extends PagingAndSortingRepository<User, Long> {

	User findByNameAndPassword(String name,String password);
}
UserService类:
@Service
@Transactional
public class UserService {

	
	@Autowired
	private UserRepository userRepo;
	
	
	public User save(User user){
		return userRepo.save(user);
	}
	
	
	public Page<User> getUsers(Integer pageNumber){
		PageRequest pageRequest = new PageRequest(pageNumber - 1, Context.PAGE_SIZE, Sort.Direction.DESC,"id");
		return userRepo.findAll(pageRequest);
	}
	
}
测试类:
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "classpath:applicationContext-core.xml")
@Transactional
public class RepositoryTest {

	@Autowired
	UserService userService;
	

	@Test
	public void getByService(){
		Page<User> page = userService.getUsers(1);
		List<User> list = page.getContent();
		for(User u:list){
			System.out.println(u.getDisplayName()+",isDisable:"+u.isDisable());
		}
	}
	
	@Test
	public void saveUser(){
		User u = new User();
		u.setName("test").setPassword("123").setDisplayName("测试用户");
		User u2 = userService.save(u);
		System.out.println(u2.getId());
	}
	
	
}
从数据库取数正常,但是保存不上。也没有报错。。

以下是问题补充:

@itwarcraft:感谢@tx15的回答。才看到是用的spring-test,自动把测试数据回滚造成的。 (2013/03/16 10:25)
加载中
0
皛尛惢
皛尛惢

<propertyname="defaultAutoCommit"value="false"/>

这句决定是否提交事务,你把它设为false,就是说明事务没有提交

事务不提交,数据是看不到数据的

要想数据库,看到数据就改为true

0
itwarcraft
itwarcraft

引用来自“tx15”的答案

<propertyname="defaultAutoCommit"value="false"/>

这句决定是否提交事务,你把它设为false,就是说明事务没有提交

事务不提交,数据是看不到数据的

原来我没写这一条,同样也是没有提交数据库。后来看了看别人的程序,对比后,拷备过来。改成true么是?
0
皛尛惢
皛尛惢

引用来自“itwarcraft”的答案

引用来自“tx15”的答案

<propertyname="defaultAutoCommit"value="false"/>

这句决定是否提交事务,你把它设为false,就是说明事务没有提交

事务不提交,数据是看不到数据的

原来我没写这一条,同样也是没有提交数据库。后来看了看别人的程序,对比后,拷备过来。改成true么是?
是的
0
itwarcraft
itwarcraft

引用来自“itwarcraft”的答案

引用来自“tx15”的答案

<propertyname="defaultAutoCommit"value="false"/>

这句决定是否提交事务,你把它设为false,就是说明事务没有提交

事务不提交,数据是看不到数据的

原来我没写这一条,同样也是没有提交数据库。后来看了看别人的程序,对比后,拷备过来。改成true么是?
刚试了下,改成true,还是没有提交成功,数据库没有存上,但是确实是发出sql语句了
0
皛尛惢
皛尛惢

引用来自“itwarcraft”的答案

引用来自“itwarcraft”的答案

引用来自“tx15”的答案

<propertyname="defaultAutoCommit"value="false"/>

这句决定是否提交事务,你把它设为false,就是说明事务没有提交

事务不提交,数据是看不到数据的

原来我没写这一条,同样也是没有提交数据库。后来看了看别人的程序,对比后,拷备过来。改成true么是?
刚试了下,改成true,还是没有提交成功,数据库没有存上,但是确实是发出sql语句了

<propertyname="hbm2ddl.auto"value="${hibernate.hbm2ddl.auto}"/>

${hibernate.hbm2ddl.auto}这个值里面是什么?
0
itwarcraft
itwarcraft

引用来自“tx15”的答案

引用来自“itwarcraft”的答案

引用来自“itwarcraft”的答案

引用来自“tx15”的答案

<propertyname="defaultAutoCommit"value="false"/>

这句决定是否提交事务,你把它设为false,就是说明事务没有提交

事务不提交,数据是看不到数据的

原来我没写这一条,同样也是没有提交数据库。后来看了看别人的程序,对比后,拷备过来。改成true么是?
刚试了下,改成true,还是没有提交成功,数据库没有存上,但是确实是发出sql语句了

<propertyname="hbm2ddl.auto"value="${hibernate.hbm2ddl.auto}"/>

${hibernate.hbm2ddl.auto}这个值里面是什么?
update
0
itwarcraft
itwarcraft

引用来自“itwarcraft”的答案

引用来自“tx15”的答案

引用来自“itwarcraft”的答案

引用来自“itwarcraft”的答案

引用来自“tx15”的答案

<propertyname="defaultAutoCommit"value="false"/>

这句决定是否提交事务,你把它设为false,就是说明事务没有提交

事务不提交,数据是看不到数据的

原来我没写这一条,同样也是没有提交数据库。后来看了看别人的程序,对比后,拷备过来。改成true么是?
刚试了下,改成true,还是没有提交成功,数据库没有存上,但是确实是发出sql语句了

<propertyname="hbm2ddl.auto"value="${hibernate.hbm2ddl.auto}"/>

${hibernate.hbm2ddl.auto}这个值里面是什么?
update
晕,才看到打印的日志说:
[org.springframework.test.context.transaction.TransactionalTestExecutionListener] - <Rolled back transaction after test execution for test context [[TestContext@9ad840 testClass = RepositoryTest, locations = array<String>['classpath:applicationContext.xml'], testInstance = test.domain.RepositoryTest@1eb7d25, testMethod = saveUser@RepositoryTest, testException = [null]]]>
------
spring-test把事务自动回滚了。。
感谢你的回复。不好意思。
0
皛尛惢
皛尛惢

引用来自“itwarcraft”的答案

引用来自“itwarcraft”的答案

引用来自“tx15”的答案

引用来自“itwarcraft”的答案

引用来自“itwarcraft”的答案

引用来自“tx15”的答案

<propertyname="defaultAutoCommit"value="false"/>

这句决定是否提交事务,你把它设为false,就是说明事务没有提交

事务不提交,数据是看不到数据的

原来我没写这一条,同样也是没有提交数据库。后来看了看别人的程序,对比后,拷备过来。改成true么是?
刚试了下,改成true,还是没有提交成功,数据库没有存上,但是确实是发出sql语句了

<propertyname="hbm2ddl.auto"value="${hibernate.hbm2ddl.auto}"/>

${hibernate.hbm2ddl.auto}这个值里面是什么?
update
晕,才看到打印的日志说:
[org.springframework.test.context.transaction.TransactionalTestExecutionListener] - <Rolled back transaction after test execution for test context [[TestContext@9ad840 testClass = RepositoryTest, locations = array<String>['classpath:applicationContext.xml'], testInstance = test.domain.RepositoryTest@1eb7d25, testMethod = saveUser@RepositoryTest, testException = [null]]]>
------
spring-test把事务自动回滚了。。
感谢你的回复。不好意思。
解决就好
0
pengcheng_1024
pengcheng_1024

引用来自“皛尛惢”的评论

引用来自“itwarcraft”的答案

引用来自“itwarcraft”的答案

引用来自“tx15”的答案

引用来自“itwarcraft”的答案

引用来自“itwarcraft”的答案

引用来自“tx15”的答案

<propertyname="defaultAutoCommit"value="false"/>

这句决定是否提交事务,你把它设为false,就是说明事务没有提交

事务不提交,数据是看不到数据的

原来我没写这一条,同样也是没有提交数据库。后来看了看别人的程序,对比后,拷备过来。改成true么是?
刚试了下,改成true,还是没有提交成功,数据库没有存上,但是确实是发出sql语句了

<propertyname="hbm2ddl.auto"value="${hibernate.hbm2ddl.auto}"/>

${hibernate.hbm2ddl.auto}这个值里面是什么?
update
晕,才看到打印的日志说:
[org.springframework.test.context.transaction.TransactionalTestExecutionListener] - <Rolled back transaction after test execution for test context [[TestContext@9ad840 testClass = RepositoryTest, locations = array<String>['classpath:applicationContext.xml'], testInstance = test.domain.RepositoryTest@1eb7d25, testMethod = saveUser@RepositoryTest, testException = [null]]]>
------
spring-test把事务自动回滚了。。
感谢你的回复。不好意思。
解决就好

我也遇到這個問題,怎麼不讓他回滾啊?

w
whzhu
在测试类上面加上这个注解就OK了 @TransactionConfiguration(defaultRollback=false)
返回顶部
顶部