Mybatis
控制台打印SQL语句
// 修改application.yml文件
mybatis:
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
指定mapper.xml文件路径
# 指定mapper.xml的文件路径
mybatis:
mapper-locations: classpath:/mapper/*.xml
传递实体参数
不加@Param注解,取值的时候直接写属性
加了@Param注解,取值必须使用对象.属性的方式
动态SQL
trim标签
insert into t_car
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="vin != null">vin,</if>
<if test="deviceId != null">device_id,</if>
<if test="fenceId != null">fence_id,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="vin != null">#{vin},</if>
<if test="deviceId != null">#{deviceId},</if>
<if test="fenceId != null">#{fenceId},</if>
</trim>
</insert>
foreach标签
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
where标签
<where>
<if test="simNo != null and simNo != ''"> and sim_no = #{simNo}</if>
<if test="deptId != null "> and dept_id = #{deptId}</if>
<if test="status != null "> and status = #{status}</if>
</where>
异常处理
MyBatis框架自定义了一个异常基类,叫做PersistenceException, 而PersistenceException是RuntimeException的子类
故Mybatis没有的异常都是非检查异常,直接使用全局异常处理器捕获即可
注释写法
使用 <!-- 注释 -->,千万别用 --(pgsql) 或者 #(mysql) 之类的
可能遇到的问题
mybatis版本号与SpringBoot不兼容
问题描述
SpringBoot 版本号为2.6.13
Mybatis 版本号为3.0.0
No qualifying bean of type 'com.example.dynamicdatasource.mapper.UserMapper' available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}
解决方案
降低Mybatis 的版本号
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<!-- <version>3.0.0</version>-->
<version>1.3.2</version>
</dependency>
参考文章
【1】控制台打印SQL语句
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!