MyBatis_01_初识

一、概述

在使用JavaWeb+JDBC进行数据库操作之后,发现其有重复、冗余的代码,简单的封装已经不能满足开发中的对效率的要求了,因此在这里引进Mybatis持久层框架的概念;
Mybatis可以用来进行对数据库进行增删改查的操作,消除了JDBC中很多复杂的手动操作,主要采用XML配置文件的方法进行映射。

二、配置Mybatis

Mybatis是如何对数据库进行操作的,其与原生的JDBC相比,到底简化了哪些部分?下面,我们开始搭建第一个Mybatis的运行环境

1、工具准备

在使用Mybatis之前,我们首先准备其需要的软件工具;
(1)idea运行环境
(2)Maven插件
(3)MySQL数据库
(4)JDK1.8

2、环境搭建

在idea下新建Maven项目,在项目中根据MVC进行结构搭建
在这里插入图片描述

3、导包

在此只对Mybatis连接数据库进行操作,不涉及WEB,因此只需导入Mybatis和MySQL的依赖即可

    <!--数据库包-->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.47</version>
    </dependency>
    <!--Mybatis-->
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.5.2</version>
    </dependency>  

4、配置文件

在resources目录下,新建mybatis-config.xml文件对Mybatis进行配置
作用:连接数据库、注册Mapper

<?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 resource="db.properties"/>
    <!--配置数据库的连接-->
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${driver}"/>
                <property name="url" value="${url}"/>
                <property name="username" value="${username}"/>
                <property name="password" value="${password}"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
<!--        每一个Mapperxml都需要注册-->
        <mapper resource="com/xawl/mybatis/dao/UserMapper.xml"/>
    </mappers>
</configuration>

外部配置文件db.properties(内部的用户名、密码、连接的数据库名需要进行更改)

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&amp;userUnicode=true&amp;characterEncoding=utf-8
username=root
password=123456

Mybatis的配置就这些,下面进行编写测试程序

三、第一个Mybatis程序

1、工具类

MyBatisUtils.java
作用:读取mybatis-config.xml配置文件,生成SqlSessionFactory、SqlSession对象
···SqlSessionFactory:是单个数据库映射关系经过编译之后的内存镜像,通过SqlSessionFactoryBuilder对象创建获得。创建后在程序运行期间一直存在,无需多次创建,因此多使用单例模式;用于生成SqlSession对象
···SqlSession:应用程序和持久层进行交互的一个重要对象,包含所有的SQL执行方法,底层封装了JDBC连接,类似于JDBC生成的Connection对象,使用后需要进行关闭;

public class MybatisUtils {
    private static SqlSessionFactory sqlSessionFactory;
    //Mybatis第一步:获取SqlSessionFactory对象
    static{
        try {
            String resource = "mybatis-config.xml";
            InputStream inputStream = Resources.getResourceAsStream(resource);
            sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        }
        catch (IOException e) {
            e.printStackTrace();
        }
    }
    //获取Sqlsession对象
    public static SqlSession getSqlSession(){
        return sqlSessionFactory.openSession(true);
    }
}

2、实体类

对应所要查询的数据库表,在pojo目录下,编写对应的实体类

3、UserMapper接口文件

在Dao层中,根据功能,编写对应的接口

public interface UserMapper {
     //获取所有User表信息
     List<User> getUserAll();
}

4、UserMapper.xml文件

一个Mapper文件对应一个接口文件,两者进行绑定,并需要在同一目录下
需要在mabatis配置文件中进行注册

<?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接口-->
<mapper namespace="com.xawl.mybatis.dao.UserMapper">
<!--    获取全部信息-->
    <select id="getUserAll" resultType="com.xawl.mybatis.pojo.User">
        select * from user;
    </select>
</mapper>

5、测试文件

在此Service没有业务逻辑,因此直接进行测试

public class UserMapperImlp {
    //查询所有User表信息
    public void getUserAll(){
        //获取seiion对象
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        //执行SQl
        UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
        List<User> list = userMapper.getUserAll();
        System.out.println(list);
        //关闭连接
        sqlSession.close();
    }
}

运行结果:

在这里插入图片描述
至此,Mybatis的配置工作完成,接下来对其进行深入学习

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值