Mybatis快速复习--快速开发

128 阅读2分钟

持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第20天,点击查看活动详情

二、快速入门

开发流程

下面我们用代码演示一遍,mybatis的开发流程

步骤1:准备数据库表

步骤2:创建项目通过maven导入jar包

步骤3:根据表创建模型类

步骤4:创建Mapper接口

步骤5:创建Mapper映射文件

步骤6:添加jdbc.properties文件

步骤7:添加Mybatis核心配置文件

步骤8:编写应用程序

这些步骤是很固定的,后期我们开发的时候也是按照这个流程来进行的。

注意:mybatis的xml配置mapper映射文件一定要会这种形式,这很重要!!!

像我们以后看开源项目的时候,很多持久层框架用的都是mybatis,然后人家写的都是xml格式的映射文件,为什么这样写呢?

因为写在xml文件里的sql语句比较好优化,而且看着很清晰!!!

步骤1:准备数据库表

create database spring_db character set utf8;
use spring_db;
create table tbl_account(
    id int primary key auto_increment,
    name varchar(35),
    money double
);

步骤2:创建项目导入jar包

项目的pom.xml添加相关依赖

<dependencies>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>5.0.5.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>druid</artifactId>
        <version>1.1.16</version>
    </dependency>
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.5.6</version>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.47</version>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>1.18.22</version>
    </dependency>
</dependencies>

步骤3:根据表创建模型类

@Data
@ToString
public class Account {
    private String name;
    private String money;
}

步骤4:创建Mapper接口

配置文件形式

public interface AccountMapper {
    Account selectById(Integer id);
}

步骤5:创建Mapper映射文件

<?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.caq.study.mapper.AccountMapper">
    <select id="selectById" resultType="com.caq.study.entity.Account">
        select * from account where id = #{id}
    </select>
</mapper>

步骤6:添加jdbc.properties文件

resources目录下添加,用于配置数据库连接四要素

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/heima_ssm
jdbc.username=root
jdbc.password=root

步骤7:添加Mybatis核心配置文件

<?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>
    <!--读取外部properties配置文件-->
    <properties resource="jdbc.properties"></properties>

    <!--数据源-->
    <environments default="mysql">
        <environment id="mysql">
            <transactionManager type="JDBC"></transactionManager>
            <dataSource type="POOLED">
                <property name="driver" value="${jdbc.driver}"></property>
                <property name="url" value="${jdbc.url}"></property>
                <property name="username" value="${jdbc.username}"></property>
                <property name="password" value="${jdbc.password}"></property>
            </dataSource>
        </environment>
    </environments>

    <!--映射文件扫描包路径-->
    <mappers>
        <package name="com.caq.study.mapper"></package>
    </mappers>
</configuration>

步骤8:编写应用程序

package com.caq.study;

import com.caq.study.entity.Account;
import com.caq.study.mapper.AccountMapper;
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 demo {
    public static void main(String[] args) throws IOException {
        // 1. 创建SqlSessionFactoryBuilder对象
        SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
        // 2. 加载SqlMapConfig.xml配置文件
        InputStream inputStream = Resources.getResourceAsStream("MybatisConfig.xml");
        // 3. 创建SqlSessionFactory对象
        SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(inputStream);
        // 4. 获取SqlSession
        SqlSession sqlSession = sqlSessionFactory.openSession();
        // 5. 执行SqlSession对象执行查询,获取结果User
        AccountMapper accountMapper = sqlSession.getMapper(AccountMapper.class);

        Account ac = accountMapper.selectById(2);
        System.out.println(ac);

        // 6. 释放资源
        sqlSession.close();
    }
}

步骤9:运行程序

image-20220607224604477

接口式编程

接口和配置文件可以动态绑定,只需要在配置文件中通过标签

<mapper namespace="com.caq.study.mapper.AccountMapper">用namespace来指定接口的全类名即可

使用mybatisX插件后,效果会更好如下:

image-20220610221252653