Mybatis初始构建项目遇到的问题

初始构建项目遇到的问题

Problem1(无法创建sqlSessison实例)

Caused by: org.apache.ibatis.exceptions.PersistenceException:

Error building SqlSession.

解决方案:大概率出现在核心配置文件的url配置中

因为是XML中需要将 “&”转义“&

art5-p01.png

如果配置正确但是出现该问题,可能是数据库连接url中的信息有误,直接自己进行排查了

Problem2(找不到绑定的Mapper)

org.apache.ibatis.binding.BindingException: Type interface top.nz.dao.UserMapper is not known to the MapperRegistry.

可能出现问题的地方

  1. 数据持久层的配置文件中namespace与数据持久层的接口不一致

art5-p02.png

  1. 没有在mybatis的核心配置文件中注册

art5-p03.png

3、使用Maven构建项目但是将xml文件没有放置于resources文件夹下,而是放在java下。

maven由于他的约定大于配置,标准的Maven项目都会有一个resources目录来存放我们所有的资源配置文件,但是我们往往在项目中不仅仅会把所有的资源配置文件都放在resources中,同时我们也有可能放在项目中的其他位置,那么默认的maven项目构建编译时就不会把我们其他目录下的资源配置文件导出到target目录中,就会导致我们的资源配置文件读取失败,从而导致我们的项目报错出现异常,比如说尤其我们在使用MyBatis框架时,往往Mapper.xml配置文件都会放在dao包中和dao接口类放在一起的,那么执行程序的时候,其中的xml配置文件就一定会读取失败,不会生成到maven的target目录中,所以我们要在项目的pom.xml文件中进行设置,建议每新建一个maven项目,就把该设置导入pom.xml文件中,以防不测。

  • 在对应Maven的pom.xml文件中加入以下语句,将java文件夹下的xml和properties可以通过
<!--在build中配置resources,来防止我们资源导出失败的问题-->
<build>
    <resources>
        <resource>
        	<directory>src/main/resources</directory>
        	<includes>
                <include>**/*.properties</include>
                <include>**/*.xml</include>
        	</includes>
        	<filtering>true</filtering>
        </resource>
        <resource>
            <directory>src/main/java</directory>
            <includes>
                <include>**/*.properties</include>
                <include>**/*.xml</include>
            </includes>
            <filtering>true</filtering>
        </resource>
    </resources>
</build>

然后请理Maven生成的target目录,重新跑一下即可。

art5-p04.png

Problem3(找不到绑定的Mapper中的方法)

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): top.nz.dao.UserMapper.getUserById

出现问题的地方,对应持久层的配置文件中,id没有和持久层接口中的方法名对应。

art5-p05.png

Problem4(找不到实体类)

Error resolving class. Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'User'. Cause: java.lang.ClassNotFoundException: Cannot find class: User

解决方案:出现问题的地方大概率为持久层配置文件中,resultType有误。将其修改为完整包路径即可。

art5-p06.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值