Mybatis入门指南

一、Mybatis基础

Mybatis是一种半自动化的持久化框架,能够帮助我们方便地完成持久层代码的编写。在Mybatis中,我们使用xml文件完成对数据库的操作。

Mybatis可以通过3种方式引入到项目中:

1、通过配置文件方式


<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis</artifactId>
    <version>3.5.2</version>
</dependency>

2、通过Spring集成方式


<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.1.1</version>
</dependency>

3、通过Spring Boot集成方式


spring:
  datasource:
    url: jdbc:mysql://localhost:3306/test
    username: root
    password: root
mybatis:
  config-location: classpath:mybatis-config.xml
  mapper-locations:
    - classpath:mapper/*.xml

二、Mybatis配置文件

Mybatis的配置文件是一个必不可少的部分,它决定了Mybatis框架的基本运行方式。它主要包含以下几个部分:

1、databaseIdProvider:数据库厂商标识

2、typeAliases:类型别名

3、environments:环境信息

4、mappers:映射文件

三、映射文件

映射文件是Mybatis框架的核心部分,它描述了Java对象与SQL语句之间的映射关系。

下面我们来看一个示例:

Java对象:


public class User {
    private int id;
    private String username;
    private String password;
    // 省略getter和setter方法
}

SQL语句:


CREATE TABLE user (
  id int(11) NOT NULL AUTO_INCREMENT,
  username varchar(50) DEFAULT NULL,
  password varchar(50) DEFAULT NULL,
  PRIMARY KEY (id)
);

映射文件:


<mapper namespace="com.mybatis.example.dao.UserDao">
    <resultMap type="User" id="userMap">
        <id property="id" column="id" />
        <result property="username" column="username" />
        <result property="password" column="password" />
    </resultMap>
    <select id="getUserById" resultMap="userMap"> 
        select id, username, password from user where id = #{id}
    </select>
</mapper>

四、Mybatis注解

除了xml文件完成映射关系之外,我们还可以使用注解的方式来完成映射关系。通过注解的方式,我们可以更加方便快捷地完成映射关系的定义。

下面是一个使用注解的示例:

Java对象:


public class User {
    private int id;
    private String username;
    private String password;
    // 省略getter和setter方法
}

SQL语句:


CREATE TABLE user (
  id int(11) NOT NULL AUTO_INCREMENT,
  username varchar(50) DEFAULT NULL,
  password varchar(50) DEFAULT NULL,
  PRIMARY KEY (id)
);

映射文件:


@Component
//@Mapper注解可以被@ComponentScan扫描到
@Mapper
public interface UserMapper {
    @Select("select id, username, password from user where id = #{id}")
    User getUserById(int id);
}

五、Mybatis调用方式

Mybatis有3种基本的调用方式:

1、SqlSession接口的调用方式

2、Mapper接口与xml的混合方式

3、Mapper接口的注解方式

下面是三种调用方式的示例:

方式一:SqlSession调用方式


String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

SqlSession sqlSession = sqlSessionFactory.openSession();
try {
    User user = sqlSession.selectOne("com.mybatis.example.dao.UserDao.getUserById", 1);
    System.out.println(user.getUsername());
} finally {
    sqlSession.close();
}

方式二:Mapper接口与xml的混合方式


String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

SqlSession sqlSession = sqlSessionFactory.openSession();
try {
    UserDao userDao = sqlSession.getMapper(UserDao.class);
    User user = userDao.getUserById(1);
    System.out.println(user.getUsername());
} finally {
    sqlSession.close();
}

方式三:Mapper接口的注解方式


@Autowired
private UserMapper userMapper;

@Test
public void testSelect() {
    User user = userMapper.getUserById(1);
    System.out.println(user.getUsername());
}

六、Mybatis插件

Mybatis插件可以在Mybatis的增删改查操作中增加拦截器,实现一些自定义的业务逻辑。

下面是一个示例:

定义拦截器:


@Intercepts({
    @Signature(type = StatementHandler.class, method = "prepare", args = { Connection.class, Integer.class })
})
public class MyInterceptor implements Interceptor {

    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        // 实现自定义的逻辑
        return invocation.proceed();
    }

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

    @Override
    public void setProperties(Properties properties) {
        // 获取自定义的一些配置信息
    }

}

在Mybatis配置文件中使用插件:


<plugins>
    <plugin interceptor="com.mybatis.example.interceptor.MyInterceptor">
        <property name="someValue" value="100"/>
    </plugin>
</plugins>

七、小结

Mybatis是一种相对成熟、易用的ORM框架,在日常开发中可以大幅度提高开发效率。了解其基础知识能够更好地为我们的开发工作提供支持。

原创文章,作者:THLW,如若转载,请注明出处:https://www.506064.com/n/136315.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
THLWTHLW
上一篇 2024-10-04 00:16
下一篇 2024-10-04 00:16

相关推荐

  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • 运维Python和GO应用实践指南

    本文将从多个角度详细阐述运维Python和GO的实际应用,包括监控、管理、自动化、部署、持续集成等方面。 一、监控 运维中的监控是保证系统稳定性的重要手段。Python和GO都有强…

    编程 2025-04-29
  • Python wordcloud入门指南

    如何在Python中使用wordcloud库生成文字云? 一、安装和导入wordcloud库 在使用wordcloud前,需要保证库已经安装并导入: !pip install wo…

    编程 2025-04-29
  • Python应用程序的全面指南

    Python是一种功能强大而简单易学的编程语言,适用于多种应用场景。本篇文章将从多个方面介绍Python如何应用于开发应用程序。 一、Web应用程序 目前,基于Python的Web…

    编程 2025-04-29
  • Python字符转列表指南

    Python是一个极为流行的脚本语言,在数据处理、数据分析、人工智能等领域广泛应用。在很多场景下需要将字符串转换为列表,以便于操作和处理,本篇文章将从多个方面对Python字符转列…

    编程 2025-04-29
  • Python小波分解入门指南

    本文将介绍Python小波分解的概念、基本原理和实现方法,帮助初学者掌握相关技能。 一、小波变换概述 小波分解是一种广泛应用于数字信号处理和图像处理的方法,可以将信号分解成多个具有…

    编程 2025-04-29
  • Python初学者指南:第一个Python程序安装步骤

    在本篇指南中,我们将通过以下方式来详细讲解第一个Python程序安装步骤: Python的安装和环境配置 在命令行中编写和运行第一个Python程序 使用IDE编写和运行第一个Py…

    编程 2025-04-29
  • FusionMaps应用指南

    FusionMaps是一款基于JavaScript和Flash的交互式地图可视化工具。它提供了一种简单易用的方式,将复杂的数据可视化为地图。本文将从基础的配置开始讲解,到如何定制和…

    编程 2025-04-29
  • Python起笔落笔全能开发指南

    Python起笔落笔是指在编写Python代码时的编写习惯。一个好的起笔落笔习惯可以提高代码的可读性、可维护性和可扩展性,本文将从多个方面进行详细阐述。 一、变量命名 变量命名是起…

    编程 2025-04-29
  • Python中文版下载官网的完整指南

    Python是一种广泛使用的编程语言,具有简洁、易读易写等特点。Python中文版下载官网是Python学习和使用过程中的重要资源,本文将从多个方面对Python中文版下载官网进行…

    编程 2025-04-29

发表回复

登录后才能评论