Spring+MyBatis 的几个基础问题

近期学习Spring+MyBatis 过程中遇到的一些问题及解决方法:

1. 问题一:

配置如下:

<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.baokang.gw.dao"></property>
<property name="sqlSessionFactory" value="sqlSessionFactory"></property>

</bean>

报错信息:

java.lang.IllegalStateException: Failed to load ApplicationContext

org.springframework.beans.factory.BeanCreationException:Error creating bean with name 

'org.mybatis.spring.mapper.MapperScannerConfigurer#0' defined in class path resource [spring/spring-mybatis.xml]: Initialization of bean failed; 

原因:因为MapperScannerConigurer实际是在解析加载bean定义阶段的,这个时候要是设置sqlSessionFactory的话,会导致提前初始化一些类,这个时候,PropertyPlaceholderConfigurer还没来得及替换定义中的变量,导致把表达式当作字符串复制了。

解决方案:

配置文件中,属性改为 sqlSessionFactoryBeanName

property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"

原理:使用sqlSessionFactoryBeanName注入,不会立即初始化sqlSessionFactory, 所以不会引发提前初始化问题。

2. 问题二:

 

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): 

com.baokang.gw.dao.IUserDao.selectByPrimaryKey

 

at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:189)
at org.apache.ibatis.binding.MapperMethod.<init>(MapperMethod.java:43)
at org.apache.ibatis.binding.MapperProxy.cachedMapperMethod(MapperProxy.java:58)
at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:51)
at com.sun.proxy.$Proxy15.selectByPrimaryKey(Unknown Source)
at com.baokang.gw.service.impl.UserServiceImpl.getUserById(UserServiceImpl.java:20)
at greenwave.TestMybatis.test(TestMybatis.java:30)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:74)
at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:83)
at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:72)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:232)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:89)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229)
at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)
at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:71)
at org.junit.runners.ParentRunner.run(ParentRunner.java:309)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:175)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:538)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:760)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:460)

 

at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:206)

首先按照一般解决思路先比对namespace,查看报错文件对应的Mapping文件中的命名空间和文件名称是否一致,我的问题原因是MyBatis生成了dao文件后,我修改了文件名称,但对应的Mapper文件没有修改导致报错。如图

框选的名称需要一致。

其次如果命名空间和文件名称都一致,就需要检查配置文件中的mapperLocations是否配置,配置内容如下。

<bean id="sqlSessionFactory"
class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<!-- 自动扫描mapping.xml文件(注意:classpath中不是包名,中间用/分隔) -->
<property name="mapperLocations"
value="classpath:com/baokang/gw/mapping/*.xml"></property>
</bean>

3. 问题三:

处理 java compiler level does not match the version of the installed java project facet 问题,

项目在从服务器或者从其他的地方加载到自己的开发环境中时,可能会出现上面的问题。主要原因是项目的java level和在开发软件中设置的java Compiler level不一致导致的。

解决方案:将项目的java 版本和设置的项目的编译版本统一即可。右键项目->Properties->Java Compiler 即可修改。

项目的设置的java 版本可在项目所在路径中找到 .settings文件夹下的org.eclipse.wst.common.project.facet.core.xml文件进行编辑。同时也可以在eclipse中选择Navigate->Show in->Navigator 找到对应项目的.setting下的org.eclipse.wst.common.project.facet.core.xml文件进行编辑。

4.问题四:

配置Mybatis打印生成的sql语句及参数(log4j)

首先在配置文件中配置控制台输出内容:

配置mybatis的配置文件

将mybatis的配置文件添加到spring的配置文件中

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值