MyBatis框架入门实例分析

发布时间:2022-08-04 10:23:21 作者:iii
来源:亿速云 阅读:188

MyBatis框架入门实例分析

目录

  1. 引言
  2. MyBatis简介
  3. MyBatis的核心组件
  4. MyBatis的配置
  5. MyBatis的映射文件
  6. MyBatis的CRUD操作
  7. MyBatis的动态SQL
  8. MyBatis的关联查询
  9. MyBatis的缓存机制
  10. MyBatis的插件机制
  11. MyBatis的优缺点
  12. 总结

引言

MyBatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。MyBatis可以使用简单的XML或注解来配置和映射原生信息,将接口和Java的POJOs(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。

本文将详细介绍MyBatis框架的基本概念、核心组件、配置方法、映射文件、CRUD操作、动态SQL、关联查询、缓存机制、插件机制以及其优缺点,并通过实例分析帮助读者快速入门。

MyBatis简介

MyBatis最初是Apache的一个开源项目iBatis,2010年这个项目由Apache Software Foundation迁移到了Google Code,并且改名为MyBatis。MyBatis是一个基于Java的持久层框架,它封装了JDBC操作的细节,使得开发者可以更加专注于SQL语句的编写和业务逻辑的实现。

MyBatis的主要特点包括: - 简单易用:MyBatis的配置和使用非常简单,开发者可以通过XML或注解来配置SQL语句。 - 灵活性强:MyBatis支持定制化SQL,开发者可以根据业务需求编写复杂的SQL语句。 - 性能优越:MyBatis通过缓存机制和延迟加载等技术,提高了数据库操作的性能。 - 易于集成:MyBatis可以与Spring等主流框架无缝集成。

MyBatis的核心组件

MyBatis的核心组件包括: - SqlSessionFactory:SqlSessionFactory是MyBatis的核心对象,它负责创建SqlSession对象。SqlSessionFactory是通过SqlSessionFactoryBuilder创建的,SqlSessionFactoryBuilder可以从XML配置文件或Java配置类中构建SqlSessionFactory。 - SqlSession:SqlSession是MyBatis的核心接口,它提供了执行SQL语句、获取映射器和管理事务的方法。SqlSession是通过SqlSessionFactory创建的,每个线程都应该有它自己的SqlSession实例。 - Mapper:Mapper是MyBatis的核心接口,它定义了执行SQL语句的方法。Mapper接口是通过SqlSession.getMapper()方法获取的,MyBatis会根据Mapper接口的方法名和参数自动生成SQL语句。 - Configuration:Configuration是MyBatis的核心配置类,它包含了MyBatis的所有配置信息,如数据源、映射器、缓存等。

MyBatis的配置

MyBatis的配置可以通过XML文件或Java配置类来完成。下面是一个简单的MyBatis XML配置文件示例:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
  PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
  <environments default="development">
    <environment id="development">
      <transactionManager type="JDBC"/>
      <dataSource type="POOLED">
        <property name="driver" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/mybatis"/>
        <property name="username" value="root"/>
        <property name="password" value="password"/>
      </dataSource>
    </environment>
  </environments>
  <mappers>
    <mapper resource="com/example/mapper/UserMapper.xml"/>
  </mappers>
</configuration>

在这个配置文件中,我们定义了一个名为development的环境,它使用JDBC事务管理器和POOLED数据源。数据源的配置包括数据库驱动、URL、用户名和密码。最后,我们通过<mappers>标签指定了映射文件的位置。

MyBatis的映射文件

MyBatis的映射文件用于定义SQL语句和结果映射。下面是一个简单的映射文件示例:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.mapper.UserMapper">
  <select id="selectUser" resultType="com.example.model.User">
    SELECT * FROM user WHERE id = #{id}
  </select>
  <insert id="insertUser" parameterType="com.example.model.User">
    INSERT INTO user (name, age) VALUES (#{name}, #{age})
  </insert>
  <update id="updateUser" parameterType="com.example.model.User">
    UPDATE user SET name = #{name}, age = #{age} WHERE id = #{id}
  </update>
  <delete id="deleteUser" parameterType="int">
    DELETE FROM user WHERE id = #{id}
  </delete>
</mapper>

在这个映射文件中,我们定义了一个名为UserMapper的命名空间,并在其中定义了四个SQL语句:selectUserinsertUserupdateUserdeleteUser。每个SQL语句都有一个唯一的ID,并且指定了参数类型和结果类型。

MyBatis的CRUD操作

MyBatis支持四种基本的CRUD操作:查询(Select)、插入(Insert)、更新(Update)和删除(Delete)。下面是一个简单的CRUD操作示例:

public class UserMapperTest {
  private SqlSessionFactory sqlSessionFactory;

  @Before
  public void setUp() throws Exception {
    String resource = "mybatis-config.xml";
    InputStream inputStream = Resources.getResourceAsStream(resource);
    sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
  }

  @Test
  public void testSelectUser() {
    try (SqlSession session = sqlSessionFactory.openSession()) {
      UserMapper mapper = session.getMapper(UserMapper.class);
      User user = mapper.selectUser(1);
      System.out.println(user);
    }
  }

  @Test
  public void testInsertUser() {
    try (SqlSession session = sqlSessionFactory.openSession()) {
      UserMapper mapper = session.getMapper(UserMapper.class);
      User user = new User();
      user.setName("John");
      user.setAge(25);
      mapper.insertUser(user);
      session.commit();
    }
  }

  @Test
  public void testUpdateUser() {
    try (SqlSession session = sqlSessionFactory.openSession()) {
      UserMapper mapper = session.getMapper(UserMapper.class);
      User user = new User();
      user.setId(1);
      user.setName("Jane");
      user.setAge(30);
      mapper.updateUser(user);
      session.commit();
    }
  }

  @Test
  public void testDeleteUser() {
    try (SqlSession session = sqlSessionFactory.openSession()) {
      UserMapper mapper = session.getMapper(UserMapper.class);
      mapper.deleteUser(1);
      session.commit();
    }
  }
}

在这个示例中,我们首先通过SqlSessionFactoryBuilder创建了一个SqlSessionFactory对象,然后在每个测试方法中通过SqlSessionFactory创建了一个SqlSession对象,并通过SqlSession获取了UserMapper接口的实例。最后,我们调用了UserMapper接口中的方法,执行了相应的CRUD操作。

MyBatis的动态SQL

MyBatis提供了强大的动态SQL功能,可以根据不同的条件生成不同的SQL语句。MyBatis的动态SQL主要通过<if><choose><when><otherwise><trim><where><set><foreach>等标签来实现。

下面是一个动态SQL的示例:

<select id="selectUsers" resultType="com.example.model.User">
  SELECT * FROM user
  <where>
    <if test="name != null">
      AND name = #{name}
    </if>
    <if test="age != null">
      AND age = #{age}
    </if>
  </where>
</select>

在这个示例中,我们使用了<where>标签和<if>标签来动态生成SQL语句。如果name参数不为空,则生成AND name = #{name};如果age参数不为空,则生成AND age = #{age}<where>标签会自动处理SQL语句中的ANDOR关键字,避免生成无效的SQL语句。

MyBatis的关联查询

MyBatis支持多种关联查询方式,包括一对一、一对多和多对多关联查询。下面是一个一对多关联查询的示例:

<resultMap id="userResultMap" type="com.example.model.User">
  <id property="id" column="id"/>
  <result property="name" column="name"/>
  <result property="age" column="age"/>
  <collection property="orders" ofType="com.example.model.Order">
    <id property="id" column="order_id"/>
    <result property="orderNo" column="order_no"/>
    <result property="amount" column="amount"/>
  </collection>
</resultMap>

<select id="selectUserWithOrders" resultMap="userResultMap">
  SELECT u.id, u.name, u.age, o.id AS order_id, o.order_no, o.amount
  FROM user u
  LEFT JOIN orders o ON u.id = o.user_id
  WHERE u.id = #{id}
</select>

在这个示例中,我们定义了一个userResultMap结果映射,其中包含了一个<collection>标签,用于映射User对象中的orders属性。<collection>标签的ofType属性指定了orders属性的类型为Order。在SQL语句中,我们通过LEFT JOIN查询了User表和Orders表,并将查询结果映射到User对象中。

MyBatis的缓存机制

MyBatis提供了两级缓存机制:一级缓存和二级缓存。一级缓存是SqlSession级别的缓存,它默认是开启的。二级缓存是Mapper级别的缓存,它需要手动开启。

一级缓存

一级缓存是SqlSession级别的缓存,它默认是开启的。当SqlSession执行查询操作时,MyBatis会将查询结果缓存到一级缓存中。如果SqlSession再次执行相同的查询操作,MyBatis会直接从一级缓存中获取结果,而不会再次访问数据库。

一级缓存的缺点是它的作用范围仅限于SqlSession,当SqlSession关闭或提交事务时,一级缓存会被清空。

二级缓存

二级缓存是Mapper级别的缓存,它需要手动开启。二级缓存的作用范围是Mapper命名空间,当多个SqlSession执行相同的查询操作时,MyBatis会从二级缓存中获取结果,而不会再次访问数据库。

要开启二级缓存,需要在MyBatis的配置文件中添加以下配置:

<settings>
  <setting name="cacheEnabled" value="true"/>
</settings>

然后在映射文件中添加<cache/>标签:

<cache/>

二级缓存的优点是它的作用范围是Mapper命名空间,多个SqlSession可以共享二级缓存。缺点是二级缓存需要手动开启,并且需要处理缓存一致性问题。

MyBatis的插件机制

MyBatis提供了插件机制,允许开发者在MyBatis的执行过程中插入自定义的逻辑。MyBatis的插件机制基于Java的动态代理,开发者可以通过实现Interceptor接口来创建自定义插件。

下面是一个简单的插件示例:

@Intercepts({
  @Signature(type = Executor.class, method = "update", args = {MappedStatement.class, Object.class})
})
public class MyPlugin implements Interceptor {
  @Override
  public Object intercept(Invocation invocation) throws Throwable {
    System.out.println("Before update");
    Object result = invocation.proceed();
    System.out.println("After update");
    return result;
  }

  @Override
  public Object plugin(Object target) {
    return Plugin.wrap(target, this);
  }

  @Override
  public void setProperties(Properties properties) {
  }
}

在这个示例中,我们创建了一个名为MyPlugin的插件,它拦截了Executor接口的update方法。在intercept方法中,我们可以在执行update方法前后插入自定义的逻辑。最后,我们需要在MyBatis的配置文件中注册这个插件:

<plugins>
  <plugin interceptor="com.example.plugin.MyPlugin"/>
</plugins>

MyBatis的优缺点

优点

缺点

总结

MyBatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。MyBatis可以使用简单的XML或注解来配置和映射原生信息,将接口和Java的POJOs(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。

本文详细介绍了MyBatis框架的基本概念、核心组件、配置方法、映射文件、CRUD操作、动态SQL、关联查询、缓存机制、插件机制以及其优缺点,并通过实例分析帮助读者快速入门。希望本文能够帮助读者更好地理解和使用MyBatis框架。

推荐阅读:
  1. mybatis入门一:mybatis框架原理
  2. Mybatis框架(一)初识Mybatis框架

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mybatis

上一篇:如何利用Python实现网站自动签到

下一篇:Node.js文件系统fs扩展fs-extra怎么使用

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》