JavaWeb:MyBatis 讲解(上篇)

1、MyBatis 简介

什么是 MyBatis

  • MyBatis 是一款优秀的持久层框架,用于简化 JDBC 开发
  • MyBatis 本是 Apache 的一个开源项目 iBatis,2010 年这个项目由 apache software foundation 迁移到了 google code,并且改名成 MyBatis。2013 年 11 月迁移到 Github

持久层

  • 负责将数据保存到数据库的那一层代码
  • javaEE 三层架构:表现层、业务层、持久层

框架

  • 框架就是一个半成品软件,是一套可重用的,通用的,软件基础代码
  • 在框架的基础上构建软件编写更加高效、规范、通用、可扩展

2、MyBatis 快速入门

搭建步骤

  1. 新建模块
  2. 导入 jar 包
  3. 编写 User 类
  4. 编写配置文件 mybatis-config.xml
  5. 修改连接池信息
  6. 编写接口
  7. 编写映射文件
  8. 编写测试类

案例演示

  • 准备 MySQL 数据
CREATE DATABASE day18;
USE day18;
CREATE TABLE USER (
id INT PRIMARY KEY AUTO_INCREMENT,
username VARCHAR(20) NOT NULL,
birthday DATE,
sex CHAR(1) DEFAULT '男',
address VARCHAR(50)
);

INSERT INTO USER VALUES (NULL, '孙悟空','1980-10-24','男','花果山水帘洞');
INSERT INTO USER VALUES (NULL, '白骨精','1992-11-12','女','白虎岭白骨洞');
INSERT INTO USER VALUES (NULL, '猪八戒','1983-05-20','男','福临山云栈洞');
INSERT INTO USER VALUES (NULL, '蜘蛛精','1995-03-22','女','盤丝洞');
  1. 新建项目

  2. 导入 jar 包

    通过 pom.xml 导入

        <dependencies>
            <!--单元测试-->
            <dependency>
                <groupId>junit</groupId>
                <artifactId>junit</artifactId>
                <version>4.12</version>
                <scope>test</scope>
            </dependency>

            <!--MySQL驱动-->
            <dependency>
                <groupId>mysql</groupId>
                <artifactId>mysql-connector-java</artifactId>
                <version>5.1.46</version>
            </dependency>

            <!--MyBatis核心包-->
            <dependency>
                <groupId>org.mybatis</groupId>
                <artifactId>mybatis</artifactId>
                <version>3.5.5</version>
            </dependency>
        </dependencies>
  3. 编写实体类

    这里记得要和数据库一致

    /**
     * 封装User表的实体类
     */

    public class User {
        private Integer id;
        private String username;
        private Date birthday;
        private String sex;
        private String address;
    }
  4. 复制 mybatis-config.xml 到 resources

  5. 修改连接池信息

    <?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>
            <!--在控制台显示SQL语句-->
            <setting name="logImpl" value="STDOUT_LOGGING"/>
        </settings>

        <environments default="development">
            <environment id="development">
                <transactionManager type="JDBC"/>
                <dataSource type="POOLED">
                    <!--配置连接池需要的参数-->
                    <property name="driver" value="驱动类全名"/>
                    <property name="url" value="数据库url"/>
                    <property name="username" value="数据库账号"/>
                    <property name="password" value="数据库密码"/>
                </dataSource>
            </environment>
        </environments>

        <mappers>
            <mapper resource="接口映射文件位置"/>
        </mappers>
    </configuration>
  6. 编写接口

    编写接口的好处是统一管理数据库的方法

    /**
     * xxxMapper就说对应xxx表的数据操作
     */

    public interface UserMapper {

        // 1、查询User表的所有数据
        List<User> selectAll();

    }
  7. 编写映射文件

    <?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="包名.接口名">
        <select id="方法名" resultType="方法返回值类型">
            SQL语句
        </select>
    </mapper>
  8. 编写测试类

    public class UserTest {

        @Test
        public void test01() throws IOException {
            //测试框架搭建情况
            //1、标记mybatis的配置环境
            String resource = "mybatis-config.xml";
            //2、加载配置环境的信息
            InputStream inputStream = Resources.getResourceAsStream(resource);
            //3、根据配置信息,生成SqlSessionFactory对象,相当于连接池
            SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            //4、从连接池获取连接
            SqlSession sqlSession = sqlSessionFactory.openSession();
            //5、获取执行sql语句的对象
            UserMapper mapper = sqlSession.getMapper(UserMapper.class);
            //6、调用方法执行sql语句
            List<User> users = mapper.selectAll();

            sqlSession.close();

            for (User user : users) {
                System.out.println(user);
            }
        }
    }

3、MyBatis 核心配置文件

MyBatis 核心配置文件的顶层结构如下

  • configuration(配置)
    • environment(环境变量)
    • transactionManager(事务管理器)
    • dataSource(数据源)
    • properties(属性)
    • settings(设置)
    • typeAliases(类型别名)
    • typeHandlers(类型处理器)
    • objectFactory(对象工厂)
    • plugins(插件)
    • environments(环境配置)
    • databaseldProvider(数据库厂商标识)
    • mappers(映射器)

typeAliases 别名

  • typeAliases 作用:给自定义的实体类取别名,让类使用更简单

    1. 在 mybatis-config.xml 里面配置,在 settings 后面
    2. 注意 mybatis-config.xml 中标签有规范的排位顺序,如果顺序有误 configuration 标签会报错
  • 方式一:

    这种方法是给单个类配置别名,但是有缺点就是如果多个类配置需要写很多个

    <!--
    typeAliases 给类名起别名
    typeAlias 给单个类配置别名
    type:原本包名+类名
    alias:起的别名
    -->

    <typeAliases>
          <typeAlias type="org.example.pojo.User" alias="User"></typeAlias   </typeAliases>


  • 方式二:

    通过扫包的方式进行配置,这样的好处就是此目录下的类都可以用

        <typeAliases>
            <package name="org.example.pojo"/>
        </typeAliases>

mapper 扫包配置

既然类名可以进行扫包,那我们的 mapper 文件也可以

如果 Mapper 接口名称和 SQL 映射文件名称相同,并在同一目录下,则可以使用包扫描的方式简化 SQL 映射文件的加载

  1. 在 mybatis-config.xml 里面配置
    <mappers>
        <package name="org.example.mapper"/>
    </mappers>
JavaWeb:MyBatis 讲解(上篇)
image-20231106183801618

原文始发于微信公众号(小林学编程):JavaWeb:MyBatis 讲解(上篇)

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

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

(0)
小半的头像小半

相关推荐

发表回复

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