Mybatis学习

一、

1.第一个mybatis程序

层层递进,SqlSession用来执行sql语句,SqlSession是与数据库的一次会话。

通过SqlSessionFactory获取SqlSession

通过SqlSessionBuilder的build()方法获取SessionFactory

2.第一个程序就找了30分钟的错(悲惨)

核心配置文件配错了,把 在写url时,把 url多加了一个 斜杠

写一个斜杠就行,下方是正确写法。

3.第一个程序的细节

核心配置文件中的 mapper 中的 url与resource属性,建议用resource

4.事务管理机制深度剖析

在mybatis-config.xml 核心配置文件中,可以通过以下的配置进行mybatis事务管理

复制代码
<transactionManager type="JDBC"/>

type属性的值有两种:① JDBC ② Managed

当使用属性值 JDBC时,开启了事务,需要手动提交事务。

当使用属性值 Managed,表示事务交给别人管理,没有开启事务,自动提交。

下图是老杜剖析的:

5.JUnit在实际开发的使用

6.Mybatis 集成日志组件

注意:logback的作用域是 test ,因此只有在测试时,对应的日志文件才会生效。

mybatis的核心配置文件中可以配置 <settings>

mybatis内部 内置了日志实现 STDOUT_LOGGING ,这时需要在mybatis的核心配置文件中,配置一下<settings> .

要想使用其他日志组件,可以引入相关依赖,然后配置其必需的配置文件,不需要在mybatis-config中配置<settings>

.dtd 文档类型约束

二、进行简单的增删改查

1.增

pojo类的对象和map可以进行传值。

但要注意:pojo类的属性名要和#{ name } 中相同,而map的key要与#{key} 中的key相同。

后面会学到 开启驼峰命名的映射,这样传 pojo类就会特别方便。

下面是 传pojo类时会出现的问题:

没有对应的getter方法,即#{a}中的名字a 需要在pojo类中获得其对应的值,但 在pojo类中没有对应的 get()来获得,即没有getA()方法。

小汇总:

2.删

当只有一个占位符时,其内部的名字可以随便写。

3.改

改 其实比较简单,直接传进去一个pojo对象就行,但注意名字可能会不匹配,因为数据库中的表名,极有可能含有 下划线,这时就不能 通过 get()方法获取相应的值。

4.查

查询单条数据

如果没有 指定相应 resultType ,就不能用Car 类型的变量来接收

源码:如下

如果不指定resultType ,就会出现异常。

查询多条数据(特别注意)

对于查询多条数据,所要 指定的resultType 仍未Car 不需要写成List<>的形式。

5.命名空间

命名空间的引入是为了解决sql 的 id 冲突。

假如有一个CarMapper1.xml 里面配置 id =selectAll, 另一个配置文件同样配置 id=selectAll,这个时候,就需要命名空间来解决问题。

在调用sqlSession.select(命名空间.id ); ,以这种形式就会解决id冲突的问题。

相关推荐
码云数智-园园1 小时前
微服务架构下的分布式事务:在一致性与可用性之间寻找平衡
开发语言
C++ 老炮儿的技术栈1 小时前
volatile使用场景
linux·服务器·c语言·开发语言·c++
hz_zhangrl1 小时前
CCF-GESP 等级考试 2026年3月认证C++一级真题解析
开发语言·c++·gesp·gesp2026年3月·gespc++一级
大阿明1 小时前
Spring Boot(快速上手)
java·spring boot·后端
Liu628881 小时前
C++中的工厂模式高级应用
开发语言·c++·算法
bearpping1 小时前
Java进阶,时间与日期,包装类,正则表达式
java
IT猿手1 小时前
基于控制障碍函数的多无人机编队动态避障控制方法研究,MATLAB代码
开发语言·matlab·无人机·openclaw·多无人机动态避障路径规划·无人机编队
邵奈一2 小时前
清明纪念·时光信笺——项目运行指南
java·实战·项目
AI科技星2 小时前
全尺度角速度统一:基于 v ≡ c 的纯推导与验证
c语言·开发语言·人工智能·opencv·算法·机器学习·数据挖掘
sunwenjian8862 小时前
Java进阶——IO 流
java·开发语言·python