前言
MyBatis 是一款优秀的持久层框架,一个半 ORM(对象关系映射)框架,它支持定制化 SQL、存储过程以及高级映`射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生类型、接口和 Java 的 POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。
MyBatis的作用
MyBatis作用是在持久层也就是访问数据库的操作,以前我们访问数据库是用JDBC来访问数据库,JDBC访问数据库需要写很多重复的代码,假如数据库访问很多还需要对数据库连接进行不停的打开连接和关闭连接,很消耗系统性能 MyBatis封装了JDBC底层访问数据库的代码,让我们程序猿只需要关心如何去写好SQL就好,不再需要去写JDBC底层的代码
MyBatis的优缺点
优点
- MyBatis封装了JBDC底层访问数据库的细节,使我们程序猿不需要与JDBC API打交道,就可以访问数据库
- MyBatis简单易学,程序猿直接编写SQL语句,适合于对SQL语句性能要求比较高的项目
- SQL语句封装在配置文件中,便于统一管理与维护,降低了程序的耦合度
- SQL代码从程序代码中彻底分离出来,可重用
- 提供了动态SQL标签,支持编写动态SQL
- 提供映射标签,支持对象与数据库的ORM字段关系映射
缺点
- 过于依赖数据库SQL语句,导致数据库移植性差,更换数据库,如果SQL语句有差异,SQL语句工作量大
- 由于xml里标签id必须唯一,导致DAO中方法不支持方法重载
MyBatis的配置文件
properties元素
properties元素描述的都是外部化,可替代的属性 一般用来配置连接数据源,我们可以使用property的节点来配置也可以使用资源路径引用
使用property子节点来配置
复制代码
使用资源路径引用
复制代码
jdbcConfig.properties里面的属性
driver=com.mysql.jdbc.Driverurl=jdbc:mysql://127.0.0.1:3306/testusername=rootpassword=123456复制代码
连接数据源的配置
复制代码
假如使用property子节点来配置和使用资源路径引用都用了,这个时候MyBatis会调用哪个勒?MyBatis会调用资源路径引用的属性值,因为资源路径引用的优先级高于property子节点的优先级
settings元素
settings是 MyBatis 中极为重要的调整设置,它们会改变 MyBatis 的运行时行为
复制代码
typeAliases元素
typeAliases元素的作用是给JavaBean取别名,方便我们在mappeer配置文件中使用
当我们没有给JavaBean取别名,mapper配置文件中获取JavaBean的时候,我们就需要获取JavaBean所在项目里面的全路径
SELECT * FROM dev_user WHERE devCode=#{devCode} AND devPassword=#{devPassword} 复制代码
接下来我们就来给JavaBean取别名
复制代码
给每个JavaBean去取一个指定的别名,这样是有缺陷的,万一项目中有很多个POJO那么工作量就大了,不过还有一种方法给指定的包里面所有的JavaBean都取一个别名,MyBatis会自动扫描所指定的包下的JavaBean并且给一个默认的别名,默认的别名为JavaBean的名称,请看下面
复制代码
mapper里面的配置文件就可以正常使用JavaBean取的别名了,不需要再去获取JavaBean的全路径了
SELECT * FROM dev_user WHERE devCode=#{devCode} AND devPassword=#{devPassword} 复制代码
environments元素
MyBatis可以配置多种环境,如开发环境、测试环境、生产环境等,我们可以灵活选择不同的配置,从而将SQL映射应用到不同的数据库环境上.这些不同的运行环境我们就可以用environments元素来配置实现
environments元素元素的配置
复制代码
假如我们想从开发环境变成测试环境只需要修改environments元素里面的default属性即可
复制代码
mappers元素
mappers映射器,说简单点就是告诉MyBatis去哪里找到SQL语句映射文件,我们可以使用类资源路径或者是URL等 用类资源路径获取映射文件
复制代码
用URL获取映射文件
复制代码
如何实现MyBatis
先给大家看一下我的项目结构
第一步 导入依赖
我的是maven项目所以只需要在pox.xml配置文件中添加关于MyBatis的依赖即可
<?xml version="1.0" encoding="UTF-8"?>4.0.0org.example MyBatis 1.0-SNAPSHOTjunit junit 4.11testmysql mysql-connector-java 6.0.6org.mybatis mybatis 3.4.4src/main/java/**/*.xml复制代码
第二步 创建MyBatis配置文件
这些配置文件上面也用讲的过这里就不做过多的解释了
<?xml version="1.0" encoding="UTF-8"?>复制代码
jdbc-config.properties里面的属性
driver=com.mysql.jdbc.Driverurl=jdbc:mysql://127.0.0.1:3306/test?serverTimezone=UTCusername=rootpassword=123456复制代码
第三步 创建接口以及映射文件
接口,普通的java接口
package com.friday.dao;import com.friday.pojo.User;import org.apache.ibatis.annotations.Param;public interface UserMapper {//@Param相对应给String userCode取了一个别名叫做userPassword,我们到写映射SQL语句的时候只有#{注解名称}即可,如#{userPassword} public User login(@Param("userCode") String userCode,@Param("userPassword") String pwd);}复制代码
映射文件
<?xml version="1.0" encoding="UTF-8"?> SELECT * FROM smbms_user WHERE userCode=#{userCode} AND userPassword=#{userPassword} 复制代码
mapper 文件里面的属性
- namespace属性 指定相对应的接口
- id属性 接口里面具体的方法名
- resultType 返回值的类型
- resultType 传进来的参数的类型
第四步 测试
package com.friday.test;import com.friday.dao.UserMapper;import com.friday.pojo.User;import org.apache.ibatis.annotations.Param;import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.IOException;import java.io.InputStream;public class MyBatisTest { public static void main(String[] args) throws IOException { //读取mybatis配置文件 String resource = "mybatis-config.xml"; //获取mybatis配置文件的输入流 InputStream is = Resources.getResourceAsStream(resource); //创建SqlSessionFactory对象 SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is); //打开sqlSession对象 SqlSession sqlSession = factory.openSession(); //获取对应的Mapper,让映射器通过命名空间和方法名称找到对应的SQL,发送给数据库执行后返回结果。 User user = sqlSession.getMapper(UserMapper.class).login("zhanghua","userPassword"); //看一下是否可以查到数据 if (user != null) { System.out.println("登录成功"); } else { System.out.println("登录失败"); } //关闭sqlSession对象 sqlSession.close(); }}复制代码
最后
大家看完有什么不懂的可以在下方留言讨论,也可以关注我私信问我,我看到后都会回答的。同时谢谢大家的观看,觉得文章对你有帮助的话记得关注我点个赞支持一下!