Mybatis 一看就懂系列(适合小白入手)

Mybatis简介

MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation
迁移到了google code,并且改名为MyBatis 。2013年11月迁移到Github。

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

MyBatis是对JDBC的封装,让我们操作数据库更加的方便、快捷,而不需把时间和精力浪费在如何封装结果集、如何注册驱动、如何获取连接上面;

总而言之,MyBaits就是用于简化我们DAO层的开发、在此之外还提供其他一些高级特性,例如动态SQL、一级缓存、二级缓存、日志管理、多表级联查询、批处理等

Mybatis的CURD

1. 创建测试表

CREATE TABLE `emp`  (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '员工姓名',
  `age` int(11) NULL DEFAULT NULL COMMENT '员工年龄',
  `addr` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '籍贯',
  `salary` decimal(10, 2) NULL DEFAULT NULL COMMENT '薪资',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 ;

INSERT INTO `emp` VALUES (1, '张三', 20, '广西来宾', 7600.00);
INSERT INTO `emp` VALUES (2, '李四', 22, '浙江绍兴', 6800.00);
INSERT INTO `emp` VALUES (3, '小明', 25, '广东云浮', 6600.00);
INSERT INTO `emp` VALUES (4, '小红', 23, '河南信阳', 7000.00);
INSERT INTO `emp` VALUES (5, '张明', 25, '山东临沂', 8000.00);

2. 编辑pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.example</groupId>
    <artifactId>mybatis</artifactId>
    <version>1.0-SNAPSHOT</version>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>


    <dependencies>
        <!-- mybatis依赖 -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.5</version>
        </dependency>

        <!--mysql依赖-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.32</version>
        </dependency>

        <!--日志依赖-->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>

        <!--测试单元-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
        </dependency>
            <dependency>
                <groupId>org.projectlombok</groupId>
                <artifactId>lombok</artifactId>
                <version>1.18.10</version>
            </dependency>
    </dependencies>
</project>

3. 创建SqlMapConfig.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>
    <!--日志配置-->
    <settings>
        <setting name="logImpl" value="STDOUT_LOGGING"/>
    </settings>
    <!--  default 默认使用那个运行环境 -->
    <environments default="dev">
        <!--配置dev运行环境-->
        <environment id="dev">
            <!--事务管理器:JDBC事务管理-->
            <transactionManager type="JDBC"></transactionManager>
            <!--POOLED指定采用mybatis内置的连接池支持-->
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"></property>
                <property name="url" value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=UTF8"></property>
                <property name="username" value="root"></property>
                <property name="password" value="root"></property>
            </dataSource>
        </environment>
    </environments>
</configuration>

4. 创建实体类

这里我们使用lombok插件,可以省去set和get等方法

package com.slyx.entity;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

/**
 * @Author lyx
 * @Version 1.0
 * @Motto 不要停止奔跑
 * @Intro:
 */
@Data
@AllArgsConstructor
@NoArgsConstructor

public class Emp {
    private Integer id;
    private String name;
    private Integer age;
    private String addr;
    private Double salary;
}

5. 查询全部

5.1 创建dao接口
package com.slyx.dao;

import com.slyx.entity.Emp;

import java.util.List;

public interface EmpDao {
    List<Emp> findAll();
}

5.2 加载接口映射文件

敲重点,会踩坑

EmpDao接口和EmpDao.xml的路径一定要一致。

还有在resource创建目录时候,要用 \ 才能分级目录。用.就是一级目录。不管你后面显示多少

在这里插入图片描述

 <!--
            select 表示执行查询sql
            id 唯一; 必须与接口中方法名称一致。
            resultType 表示执行查询SQL封装的实体类对象。如果放回集合,只需要指定集合中元素的类型即可。
            标签体中存放要执行的select语句 
    -->
<?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.slyx.dao.EmpDao">
    <select id="findAll" resultType="com.slyx.entity.Emp">
        select * from emp;
    </select>
</mapper>
5.3 加载映射文件

在sqlMapConfig中编辑

 <!--加载映射文件-->
    <mappers>
        <mapper resource="com/slyx/dao/EmpDao.xml"></mapper>
    </mappers>

测试类

import com.slyx.dao.EmpDao;
import com.slyx.entity.Emp;
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 org.junit.After;
import org.junit.Before;
import org.junit.Test;

import java.io.InputStream;
import java.util.List;

/**
 * @Author lyx
 * @Version 1.0
 * @Motto 不要停止奔跑
 * @Intro:
 */
public class test {
    private InputStream in;
    private SqlSessionFactoryBuilder Sql;
    private SqlSessionFactory factory;
    private SqlSession session;
    private EmpDao empDao;

    @Before
    public void Before() throws Exception {

        //获取主配置文件流
        in = Resources.getResourceAsStream("SqlMapConfig.xml");

        //获取主配置文件流
        Sql = new SqlSessionFactoryBuilder();

        //获取session工厂
        factory = Sql.build(in);

        //获取session会话域
        session = factory.openSession();
        empDao = session.getMapper(EmpDao.class);
    }

    @After
    public void after() throws Exception {
        in.close();
        session.close();
    }

    @Test
    public void test1(){
        List<Emp> all = empDao.findAll();
        System.out.println(all);
    }
}

5.4 测试结果

在这里插入图片描述


6. 保存操作

6.1 创建到接口
 void save(Emp emp);
6.2 编写接口映射文件
  <!--
        id: 标识唯一一条SQL语句,和接口方法名保持一致
        parameterType:SQL语句的入参类型,也就是方法参数
        #{}:取值符号
        #{name}:对应的是Emp对象的属性
        OGNL是Object-Graph Navigation Language的缩写,它是一种功能强大的表达式语言
    -->
 <insert id="save" parameterType="com.slyx.entity.Emp">
        insert into emp values (null,#{name},#{age},#{addr},#{salary})
    </insert>
6.3 编写测试类
 @Test
    public void test3(){
        Emp emp = new Emp(null, "小林", 20, "福建厦门", 8000.0);
        empDao.save(emp);
        System.out.println(emp);
        session.commit();
    }
6.4 测试结果

在这里插入图片描述


id怎么能是null呢,不行。重新配置

保存返回值ID
方法一
<!--
    只支持主键自增长的数据库。在oracle中不能使用,因为需要查询序列值
    useGeneratedKeys="true" 获取主键值
-->

编写EmpDao.xml

   <insert id="save" parameterType="com.slyx.entity.Emp" useGeneratedKeys="true" keyColumn="id" keyProperty="id">
        insert into emp values (null,#{name},#{age},#{addr},#{salary})
    </insert>

测试结果
在这里插入图片描述


方法二
<!--
    selectKey:相当于执行MySQL LAST_INSERT_ID()函数
        keyColumn:列名称
        keyProperty:实体属性名称
        resultType:类型
        order:
            after:在数据插入之后获取值(适用于列自增)
            before:在数据插入之前获取值(适用于oracle的序列增长)
-->

编写EmpDao.xml

<insert id="save" parameterType="com.slyx.entity.Emp">
        <selectKey keyColumn="id" keyProperty="id" resultType="Integer" order="AFTER">
            select LAST_INSERT_ID()
        </selectKey>
            insert into emp values(null,#{name},#{age},#{addr},#{salary})
    </insert>

测试结果
在这里插入图片描述


7. 修改操作

7.1 创建到接口
  void update(Emp emp);
7.2 编写接口映射文件
  <update id="update" parameterType="com.slyx.entity.Emp">
        update emp set name=#{name},age=#{age},addr=#{addr},salary=#{salary} where id=#{id};
    </update>
7.3 编写测试类
  @Test
    public void test4() {
        Emp emp = new Emp(1, "小小", 18, "哈尔滨", 2000.0);
        empDao.update(emp);
        System.out.println(emp);
        session.commit();
    }
7.4 测试结果

在这里插入图片描述


8. 删除操作

8.1 创建到接口
 void delete(Integer id);
8.2 编写接口映射文件
 <delete id="delete" parameterType="java.lang.Integer">
        delete  from emp where id =#{id}
    </delete>
8.3 编写测试类
  @Test
    public void test5(){
        empDao.delete(6);
        session.commit();
    }
8.4 测试结果

在这里插入图片描述


9. 统计

9.1 创建到接口
 Long counts();
9.2 编写接口映射文件
 <select id="counts" resultType="java.lang.Long">
        select count(1) from emp
    </select>
9.3 编写测试类
 @Test
    public void test6() throws Exception {
        Long count = empDao.counts();
        System.out.println("查到共有"+count+"记录");
    }
9.4 测试结果

在这里插入图片描述


10. 模糊查询

10.1 创建到接口
 List<Emp> findByName(String name);
10.2 编写接口映射文件
 <select id="findByName" parameterType="java.lang.String" resultType="com.slyx.entity.Emp">
        select * from emp where name like #{name}
    </select>
10.3 编写测试类
 @Test
    public void test2(){
        List<Emp> byName = empDao.findByName("%小%");
        for (Emp e : byName) {
            System.out.println(e);
        }
    }
10.4 测试结果

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

眼里只有码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值