持续创作,加速成长!这是我参与「掘金日新计划 · 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:运行程序
接口式编程
接口和配置文件可以动态绑定,只需要在配置文件中通过标签
<mapper namespace="com.caq.study.mapper.AccountMapper">用namespace来指定接口的全类名即可
使用mybatisX插件后,效果会更好如下: