【Mybatis】Mybatis简介及第一个简单demo搭建

生活中,最使人疲惫的往往不是道路的遥远,而是心中的郁闷;最使人痛苦的往往不是生活的不幸,而是希望的破灭;最使人颓废的往往不是前途的坎坷,而是自信的丧失;最使人绝望的往往不是挫折的打击,而是心灵的死亡。所以我们要有自己的梦想,让梦想的星光指引着我们走出落漠,走出惆怅,带着我们走进自己的理想。

导读:本篇文章讲解 【Mybatis】Mybatis简介及第一个简单demo搭建,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

闲话

最近开始学习《计算机网络:自顶向下方法》,买的是一本实体书,就不方便上传博客了,所以打算抽空把工作中常用的框架复习一遍,巩固巩固

一、什么是Mybatis

1、官方文档:Mybatis官网

2、简介

  • MyBatis 是一款优秀的持久层框架(dao层,主要与数据库进行交互),它支持自定义 SQL、存储过程以及高级映射
  • MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作
  • MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java – Objects,普通老式 Java 对象)为数据库中的记录

数据持久化:就是将程序的数据在持久状态(数据库)和瞬时状态(内存)转化的过程

3、为什么使用mybatis:JDBC代码复杂,使用mybatis简化操作,自动化

4、优点:

  • 简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件易于学习,易于使用
  • 灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
  • 解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
  • 提供映射标签,支持对象与数据库的orm字段关系映射
  • 提供对象关系映射标签,支持对象关系组建维护
  • 提供xml标签,支持编写动态sql

5、关于#和$
#{}是预编译处理,${}是字符串替换

默认情况下,我们都会使用 #{}参数语法时,MyBatis 会创建PreparedStatement 参数占位符,并通过占位符安全地设置参数(就像使用 ? 一样,防止SQL注入)。 这样做更安全,更迅速,通常也是首选做法,而${}创建的是Statement 参数占位符

不过有时你就是想直接在 SQL 语句中直接插入一个不转义的字符串。
比如 ORDER BY 子句,这时候你可以:

ORDER BY ${columnName}

这样,MyBatis 就不会修改或转义该字符串了

二、一个简单的项目搭建

1、依赖导入
我们创建一个maven项目,所以需要配置pom.xml文件

<dependencies>
	<!--Mybatis-->
	<dependency>
    	<groupId>org.mybatis</groupId>
    	<artifactId>mybatis</artifactId>
    	<version>3.5.6</version>
	</dependency>
	<!--MySQL驱动-->
	<dependency>
    	<groupId>mysql</groupId>
    	<artifactId>mysql-connector-java</artifactId>
    	<version>8.0.27</version>
	</dependency>
	<!--Junit-->
	<dependency>
    	<groupId>junit</groupId>
    	<artifactId>junit</artifactId>
    	<version>4.13.1</version>
    	<scope>test</scope>
	</dependency>
</dependencies>

2、核心配置
配置核心配置文件mybatis-config.xml,连接本地的数据库
注意:数据库连接url里,参数连接符需要用 &amp;
另外,记得设置项目的编码为utf-8,否则运行后面的测试类会因为这里注释中有中文报错,路径为setting-File Encodings

<?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">
                <!--驱动配置,com.mysql.jdbc.driver -->
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=true&amp;useUnicode=true&amp;characterEncoding=UTF-8"/>
                <property name="username" value="root"/>
                <property name="password" value="root"/>
            </dataSource>
        </environment>
    </environments>

    <!--每一个mapper.xml文件都需要在核心配置文件中注册-->
    <mappers>
        <mapper resource="com/decade/mapper/UserMapper.xml"/>
    </mappers>
</configuration>

但是,由于maven约定大于配置的原因,我们写的配置文件如果放在Java文件夹下,那么就可能会出现无法被导出或生效的问题,所以,我们需要在pom文件里进行如下配置

	<!--在build中配置resources,来防止我们资源导出失败的问题-->
    <build>
        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <includes>
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                </includes>
                <filtering>true</filtering>
            </resource>
            <resource>
                <directory>src/main/java</directory>
                <includes>
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                </includes>
                <filtering>true</filtering>
            </resource>
        </resources>
    </build>

3、代码编写

  • 首先编写一个Mybatis工具类,获取sqlSession,sqlSession完全包含了面向数据库执行sql命令所需要的方法
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;

/**
 * Mybatis工具类
 */
public class MybatisUtils {

    private static SqlSessionFactory sqlSessionFactory;

    static {
        try {
            // 使用Mybatis第一步:获取sqlSession
            String resource = "mybatis-config.xml";
            InputStream inputStream = Resources.getResourceAsStream(resource);
            sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    // 既然有了sqlSessionFactory,我们就可以得到sqlSession实例了
    // sqlSession完全包含了面向数据库执行sql命令所需要的方法,如果要开启自动提交事务,openSession中设置true即可
    public static SqlSession getSqlSession() {
        return sqlSessionFactory.openSession();
    }
}
  • 编写实体类
package com.decade.entity;

/**
 * 人员信息
 */
public class User {

    private String id;

    private String name;

    private int age;

    private String sex;

    public User(String userId, String name, int age, String sex) {
        this.id = userId;
        this.name = name;
        this.age = age;
        this.sex = sex;
    }

    public String getName() {
        return name;
    }

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    @Override
    public String toString() {
        return "User{"
            + "id='" + id + '\''
            + ", name='" + name + '\''
            + ", age=" + age
            + ", sex='" + sex + '\''
            + '}';
    }
}
  • Dao接口
import com.decade.entity.User;

import java.util.List;

public interface UserDao {
    List<User> getUserInfo();
}
  • 接口实现类(由jdbc实现类变成了Mapper.xml配置文件)
    namespace绑定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.decade.mapper.UserDao">

    <select id="getUserInfo" resultType="com.decade.entity.User">
        select * from t_decade_user;
    </select>
</mapper>
  • 编写一个测试类进行测试
import com.decade.entity.User;
import com.decade.mapper.UserDao;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import com.decade.utils.MybatisUtils;

import java.util.List;

public class UserDaoTest {

   @Test
   public void test() {
       // 第一步:获取sqlSession对象
       SqlSession sqlSession = MybatisUtils.getSqlSession();

       try {
           // 一共两种方式进行查询
           UserDao userDao = sqlSession.getMapper(UserDao.class);
           List<User> userList = userDao.getUserInfo();

           List<User> userInfos = sqlSession.selectList("com.decade.mapper.UserDao.getUserInfo");

           // 循环输出查询到的user信息
           userList.forEach(System.out::println);
       } catch (Exception e) {
           e.printStackTrace();
       } finally {
           // 关闭sqlSession
           sqlSession.close();
       }
   }
}

运行测试类结果如下
在这里插入图片描述

如有错误,欢迎指正

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/136791.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!