Mybatis的坑——SqlSessionFactory,Mapper接口和mapper.xml映射文件

本文介绍了在Spring Boot项目中整合Mybatis时遇到的问题,包括mapper接口与mapper.xml映射文件的位置配置。当使用maven打包时,mapper.xml会被过滤掉,可以通过在pom.xml中配置或在resource目录下创建对应目录来解决。在Spring Boot中,可以通过注解方式替代xml配置,但需注意避免与Spring Boot内置配置冲突,可能导致mapper接口和映射文件匹配失败。解决方案包括删除自定义SqlSessionFactory配置或明确指定mapper位置。
摘要由CSDN通过智能技术生成

在平时的开发中,连接数据库进行增删改查的方案有很多,常见的直接有:

  1. jdbc,但是如果直接使用jdbc,会存在很多问题。首先,频繁的创建连接和释放会造成资源的浪费从而影响性能,这个问题可以用数据库连接池来解决。而且,还有一种情况比较坑,就是在开发中,有时新手在开发中会忘记close掉connection,造成连接数不够,无法访问数据库。一般企业开发中,如果使用jdbc,也不会直接手写,而是开发一个访问数据库连接的对象,比如DBACCESS之类的,在这个类里面进行连接进行创建和关闭,这样就不会踩到这个坑了。第二,sql会直接写在代码里面,导致的结果是如果我们想要只想要改变下查询的条件或者数据库表结构变化,需要我们重新编写sql语句,那么我们只能修改代码,维护起来就不是很方便。如果不嵌在代码里,而是用一个配置文件来保存sql,那么事情就变得简单起来了。

  2. JdbcTemplate。这是spring自带的数据库操作持久层框架。目前不是很熟悉这块,等有机会会好好看。等填坑。。。

  3. JPA

  4. Mybatis。Mybatis最近在创建springboot项目,整合Mybatis时,遇到了一些常见的问题,不过在网上没找到答案,自己把问题列出来,从而在以后的开发中,能够避免这一块。
    项目目录结构:
    在这里插入图片描述
    mapper接口在com.example.demo.mapper目录下。正常情况下,mapper.xml文件是可以直接放在和XXXmapper.java接口同包下的,这样spring可以自动扫描到,这是不需要我们再在application.properties里配置mybatis.mapper-locations=classpath:mappers/*.xml之类的。但是对于这种情况,我们在在使用maven打包时,会自动过滤掉除了java之类的其他文件,这个时候,我们可以在pom.xml文件里面配置

<build>
		<!-- 打包时不要忽略xml文件 -->
		<resources>
			<resource>
				<directory>src/main/java</directory>
				<includes>
					
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值