`
blueram
  • 浏览: 756875 次
  • 性别: Icon_minigender_1
  • 来自: 郑州
社区版块
存档分类
最新评论

Mybatis与Hibernate共存项目调用存储过程

 
阅读更多

项目中同时使用Hibernate(用于权限的基础框架)+Mybatis(业务开发),最近用到Mybatis调用存储过程,这下问题可来了。

开始在junit里面测试,不行,一直有一个空指针。哭

junit的配置类

package com.rixing;

import org.junit.runner.RunWith;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.TestExecutionListeners;
import org.springframework.test.context.junit4.AbstractTransactionalJUnit4SpringContextTests;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.support.DependencyInjectionTestExecutionListener;
import org.springframework.test.context.transaction.TransactionConfiguration;
import org.springframework.transaction.annotation.Transactional;

/**
 * User: renjunjie
 * Date: 13-7-9 上午10:24
 * Function:
 */
@RunWith(SpringJUnit4ClassRunner.class)
@TestExecutionListeners( { DependencyInjectionTestExecutionListener.class })
@ContextConfiguration(locations={"classpath:spring-test.xml","classpath:spring-data-test.xml"})
@TransactionConfiguration(transactionManager="transactionManager",defaultRollback=true)
public class SpringTest extends AbstractTransactionalJUnit4SpringContextTests {
}

 这是一个带有事务控制的测试基类。经过仔细查看发现了错误代码里面有hibernate的内容,奇怪了,用mybatis怎么会用到hibernate呢。想到配置事务的时候是用HibernateTransactionManager统一管理的,难道是这个问题。更改测试基类

@RunWith(SpringJUnit4ClassRunner.class)
@TestExecutionListeners( { DependencyInjectionTestExecutionListener.class })
@ContextConfiguration(locations={"classpath:spring-test.xml","classpath:spring-data.xml"})
public class OracleFunTest {

 直接运行,通过了。

然后在程序里面测试,发现还是有问题,问题在aop配置的事务。改正不需要事务控制的全部

 <tx:method name="*" propagation="NEVER" />

 这下可以了。

 

 

mybatis调用oracle带结果集的存储过程的方法,仔细查看mybatis的手册,发现oracle的结果集必须是自定义的resultMap。

http://hillfallshore.iteye.com/blog/1462355

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics