记录自己的MyBatis学习的笔记,学习课程是通过B站尚硅谷的视频学习。
@Description MyBatis学习
@Author Van
①MyBatis简介
1.MyBatis历史:
1.MyBatis最初是Apache的一个开源项目iBatis,2010年6月这个项目由Apache Software Foundation迁移到了Google Code。
随着开发团队转投Google Code旗下, iBatis3.x正式更名为MyBatis。代码于2013年11月迁移到Github。
2.是一个基于Java的持久层框架。 iBatis提供的持久层框架包括SQL Maps和Data Access Objects(DAO)。
2.MyBatis特性
1) MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架
2) MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集
3) MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录
4) MyBatis 是一个 半自动的ORM(Object Relation Mapping)框架
3.MyBatis下载::https://github.com/mybatis/mybatis-3
4.和其它持久化层技术对比
1.JDBC
SQL 夹杂在Java代码中耦合度高,导致硬编码内伤
维护不易且实际开发需求中 SQL 有变化,频繁修改的情况多见
代码冗长,开发效率低
2.Hibernate 和 JPA
操作简便,开发效率高
程序中的长难复杂 SQL 需要绕过框架
内部自动生产的 SQL,不容易做特殊优化
基于全映射的全自动框架,大量字段的 POJO 进行部分映射时比较困难。
反射操作太多,导致数据库性能下降
3.MyBatis
轻量级,性能出色
SQL 和 Java 编码分开,功能边界清晰。Java代码专注业务、SQL语句专注数据
开发效率稍逊于HIbernate,但是完全能够接受
②搭建MyBatis
1.开发环境
IDE:idea 2021.1.3
构建工具:maven 3.8.1
MySQL版本:MySQL 8.0.17
MyBatis版本:MyBatis 3.5.7
2.创建maven工程
a>打包方式:jar
b>引入依赖
jar
org.mybatis
mybatis
3.5.7
junit
junit
4.12
test
mysql
mysql-connector-java
8.0.26
3.创建MyBatis的核心配置文件
》习惯上命名为mybatis-config.xml,这个文件名仅仅只是建议,并非强制要求。将来整合Spring之后,这个配置文件可以省略,所以大家操作时可以直接复制、粘贴。
》核心配置文件主要用于配置连接数据库的环境以及MyBatis的全局配置信息
》核心配置文件存放的位置是src/main/resources目录下
4.创建mapper接口
1.MyBatis中的mapper接口相当于以前的dao。但是区别在于,mapper仅仅是接口,我们不需要提供实现类。
2.一般会有一个和bean同一层的mapper包下创建一个接口。
5.创建MyBatis的映射文件
1.相关概念:ORM(Object Relationship Mapping)对象关系映射。
对象:Java的实体类对象
关系:关系型数据库
映射:二者之间的对应关系
java 数据库
类 表
属性 字段/列
对象 记录/行
2.映射文件的命名规则:
1.表所对应的实体类的类名+Mapper.xml 例如:表t_user,映射的实体类为User,所对应的映射文件为UserMapper.xml
2.因此一个映射文件对应一个实体类,对应一张表的操作
3.MyBatis映射文件用于编写SQL,访问以及操作表中的数据
4.MyBatis映射文件存放的位置是src/main/resources/mappers目录下
3.MyBatis中可以面向接口操作数据,要保证两个一致:
a>mapper接口的全类名和映射文件的命名空间(namespace)保持一致
b>mapper接口中方法的方法名和映射文件中编写SQL的标签的id属性保持一致
要有4个东西:表---实体类---mapper接口---映射文件
mybatis-config.xml:
UserMapper.xml:
insert into t_user values(null,'admin','123456',23,'男','maomao@qq.com')
6.执行语句---JUnit测试
//sqlSession默认不自动提交事务,需要打开传值true就行
@Test
public void testMyBatis() throws IOException {
//1.mybatis提供了一个SQLSession,需要先加载核心配置文件
InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
//2.创建SqlSessionFactoryBuilder对象
SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
//3.通过核心配置文件所对应的字节输入流创建工厂类SqlSessionFactory,生产SqlSession对象
SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
//4.创建SqlSession对象,此时通过SqlSession对象所操作的sql都必须手动提交或回滚事务
SqlSession sqlSession = sqlSessionFactory.openSession();
//SqlSession sqlSession = sqlSessionFactory.openSession(true); 代表自动提交
//5.通过代理模式创建UserMapper接口的代理实现类对象
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
//6./调用UserMapper接口中的方法,就可以根据UserMapper的全类名匹配元素文件,通过调用的方法名匹配映射文件中的SQL标签,并执行标签中的SQL语句
int result = mapper.insertUser();
//7.提交事务,mybatis遵循原生jdbc事务,在执行之后必须提交事务或者回滚才能生效
sqlSession.commit();
System.out.println(result);
}
SqlSession:代表Java程序和数据库之间的会话。(HttpSession是Java程序和浏览器之间的会话)
SqlSessionFactory:是“生产”SqlSession的“工厂”。
工厂模式:如果创建某一个对象,使用的过程基本固定,那么我们就可以把创建这个对象的相关代码封装到一个“工厂类”中,以后都使用这个工厂类来“生产”我们需要的对象。
7.加入log4j日志文件
1.加入依赖
log4j
log4j
1.2.17
2.加入log4j的配置文件
log4j的配置文件名为log4j.xml,存放的位置是src/main/resources目录下
3.日志的级别
FATAL(致命)>ERROR(错误)>WARN(警告)>INFO(信息)>DEBUG(调试)
从左到右打印的内容越来越详细
8.mybatis的增删改查
1.添加
insert into t_user values(null,'admin','123456',23,'男')
2.删除
delete from t_user where id = 7
3.修改
同上
4.查询一个实体类对象