百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

看阿里P7讲MyBatis:从MyBatis的理解以及配置和实现全帮你搞懂

bigegpt 2024-08-03 11:47 1 浏览

前言

MyBatis 是一款优秀的持久层框架,一个半 ORM(对象关系映射)框架,它支持定制化 SQL、存储过程以及高级映`射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生类型、接口和 Java 的 POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

MyBatis的作用

MyBatis作用是在持久层也就是访问数据库的操作,以前我们访问数据库是用JDBC来访问数据库,JDBC访问数据库需要写很多重复的代码,假如数据库访问很多还需要对数据库连接进行不停的打开连接和关闭连接,很消耗系统性能 MyBatis封装了JDBC底层访问数据库的代码,让我们程序猿只需要关心如何去写好SQL就好,不再需要去写JDBC底层的代码

MyBatis的优缺点

优点

  • MyBatis封装了JBDC底层访问数据库的细节,使我们程序猿不需要与JDBC API打交道,就可以访问数据库
  • MyBatis简单易学,程序猿直接编写SQL语句,适合于对SQL语句性能要求比较高的项目
  • SQL语句封装在配置文件中,便于统一管理与维护,降低了程序的耦合度
  • SQL代码从程序代码中彻底分离出来,可重用
  • 提供了动态SQL标签,支持编写动态SQL
  • 提供映射标签,支持对象与数据库的ORM字段关系映射

缺点

  • 过于依赖数据库SQL语句,导致数据库移植性差,更换数据库,如果SQL语句有差异,SQL语句工作量大
  • 由于xml里标签id必须唯一,导致DAO中方法不支持方法重载

MyBatis的配置文件

properties元素

properties元素描述的都是外部化,可替代的属性 一般用来配置连接数据源,我们可以使用property的节点来配置也可以使用资源路径引用

使用property子节点来配置

    <properties>
        <property name="driver" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql:///mybatis"/>
        <property name="username" value="root"/>
        <property name="password" value="root"/>
    </properties>

复制代码

使用资源路径引用

    <properties resource="jdbcConfig.properties"/>

复制代码

jdbcConfig.properties里面的属性

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/test
username=root
password=123456

复制代码

连接数据源的配置

    <dataSource type="POOLED">
        <property name="driver" value="${driver}"/>
        <property name="url" value="${url}"/>
        <property name="username" value="${username}"/>
        <property name="password" value="${password}"/>
    </dataSource>

复制代码

假如使用property子节点来配置和使用资源路径引用都用了,这个时候MyBatis会调用哪个勒?MyBatis会调用资源路径引用的属性值,因为资源路径引用的优先级高于property子节点的优先级

settings元素

settings是 MyBatis 中极为重要的调整设置,它们会改变 MyBatis 的运行时行为

    <settings>
        <!-- 全局映射器启用缓存 -->
        <setting name="cacheEnabled" value="true"/>

        <!-- 查询时,关闭关联对象即时加载以提高性能 -->
        <setting name="lazyLoadingEnabled" value="true"/>

        <!-- 设置关联对象加载的形态,此处为按需加载字段 (加载字段由 SQL指 定 ),不会加载关联表的所有字段,以提高性能 -->
        <setting name="aggressiveLazyLoading" value="false"/>

        <!-- 对于未知的 SQL查询,允许返回不同的结果集以达到通用的效果 -->
        <setting name="multipleResultSetsEnabled" value="true"/>

        <!-- 允许使用列标签代替列名 -->
        <setting name="useColumnLabel" value="true"/>

        <!-- 允许使用自定义的主键值 (比如由程序生成的 UUID 32位编码作为键值 ),数据表的 PK生成策略将被覆盖 -->
        <setting name="useGeneratedKeys" value="true"/>

        <!-- 给予被嵌套的 resultMap以字段 -属性的映射支持 -->
        <setting name="autoMappingBehavior" value="FULL"/>

        <!-- 对于批量更新操作缓存 SQL以提高性能 -->
        <setting name="defaultExecutorType" value="BATCH"/>

        <!-- 数据库超过 25000秒仍未响应则超时 -->
        <setting name="defaultStatementTimeout" value="25000"/>
    </settings>

复制代码

typeAliases元素

typeAliases元素的作用是给JavaBean取别名,方便我们在mappeer配置文件中使用

当我们没有给JavaBean取别名,mapper配置文件中获取JavaBean的时候,我们就需要获取JavaBean所在项目里面的全路径

    <!--省略部分代码-->
    <select id="login" resultType="cn.friday.pojo.DevUser">
        SELECT * FROM dev_user WHERE devCode=#{devCode} AND devPassword=#{devPassword}
    </select>

复制代码

接下来我们就来给JavaBean取别名

    <typeAliases>
        <typeAlias type="cn.friday.pojo.DevUser" alias="devUser"/>
        <typeAlias type="cn.friday.pojo.AppInfo" alias="appInfo"/>
    </typeAliases>

复制代码

给每个JavaBean去取一个指定的别名,这样是有缺陷的,万一项目中有很多个POJO那么工作量就大了,不过还有一种方法给指定的包里面所有的JavaBean都取一个别名,MyBatis会自动扫描所指定的包下的JavaBean并且给一个默认的别名,默认的别名为JavaBean的名称,请看下面

    <typeAliases>
        <package name="cn.friday.pojo"/>
    </typeAliases>

复制代码

mapper里面的配置文件就可以正常使用JavaBean取的别名了,不需要再去获取JavaBean的全路径了

    <!--省略部分代码-->
    <select id="login" resultType="DevUser">
        SELECT * FROM dev_user WHERE devCode=#{devCode} AND devPassword=#{devPassword}
    </select>

复制代码

environments元素

MyBatis可以配置多种环境,如开发环境、测试环境、生产环境等,我们可以灵活选择不同的配置,从而将SQL映射应用到不同的数据库环境上.这些不同的运行环境我们就可以用environments元素来配置实现

environments元素元素的配置

    <!--开发环境-->
    <!--default属性表示在默认的情况下我们将启用的数据源-->
    <environments default="development">
    <!--id属性用来标识一个数据源的,方便在MyBatis中使用 -->
        <environment id="development">
            <!-- 使用jdbc事务管理 -->
            <transactionManager type="JDBC"/>
            <!-- 配置数据库连接池 -->
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://127.0.0.1:3306/test"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>

        <!--我们在来配置一个测试环境-->
         <environment id="test">
            <!-- 使用jdbc事务管理 -->
            <transactionManager type="JDBC"/>
            <!-- 配置数据库连接池 -->
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://127.0.0.1:3306/test1"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>

复制代码

假如我们想从开发环境变成测试环境只需要修改environments元素里面的default属性即可

 <environments default="test">
    <!--省略部分代码-->
 </environments>

复制代码

mappers元素

mappers映射器,说简单点就是告诉MyBatis去哪里找到SQL语句映射文件,我们可以使用类资源路径或者是URL等 用类资源路径获取映射文件

    <mappers>
        <mapper resource="cn/friday/dao/developer/DevUserMapper.xml"/>
        <mapper resource="cn/friday/dao/developer/AppInfoMapper.xml"/>
    </mappers>

复制代码

用URL获取映射文件

    <mappers>
          <mapper url="file:///D:/mappers/DevUserMapper.xml"/>
          <mapper url="file:///D:/mappers/AppInfoMapper.xml"/>
    </mappers>

复制代码

如何实现MyBatis

先给大家看一下我的项目结构


第一步 导入依赖

我的是maven项目所以只需要在pox.xml配置文件中添加关于MyBatis的依赖即可

<?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>

    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.11</version>
            <scope>test</scope>
        </dependency>

        <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>6.0.6</version>
    </dependency>

        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.4.4</version>
        </dependency>

    </dependencies>

    <build>
    <resources>
        <resource>
            <directory>src/main/java/</directory>
            <includes>
                <include>**/*.xml</include>
            </includes>
        </resource>
    </resources>
    </build>
</project>

复制代码

第二步 创建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 resource="jdbc-config.properties"/>

    <typeAliases>
        <package name="com.friday.pojo"/>
    </typeAliases>

    <environments default="test">
        <environment id="test">
            <transactionManager type="JDBC"></transactionManager>
            <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>
        <mapper resource="com/friday/dao/UserMapper.xml"></mapper>
    </mappers>
</configuration>

复制代码

jdbc-config.properties里面的属性

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/test?serverTimezone=UTC
username=root
password=123456

复制代码

第三步 创建接口以及映射文件

接口,普通的java接口

package com.friday.dao;

import com.friday.pojo.User;
import org.apache.ibatis.annotations.Param;

public interface UserMapper {
//@Param相对应给String userCode取了一个别名叫做userPassword,我们到写映射SQL语句的时候只有#{注解名称}即可,如#{userPassword}
    public User login(@Param("userCode") String userCode,@Param("userPassword") String pwd);
}

复制代码

映射文件

<?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.friday.dao.UserMapper">
    <select id="login" resultType="User" parameterType="string">
        SELECT * FROM smbms_user WHERE userCode=#{userCode} AND userPassword=#{userPassword}
    </select>
</mapper>

复制代码

mapper 文件里面的属性

  • namespace属性 指定相对应的接口
  • id属性 接口里面具体的方法名
  • resultType 返回值的类型
  • resultType 传进来的参数的类型

第四步 测试

package com.friday.test;

import com.friday.dao.UserMapper;
import com.friday.pojo.User;
import org.apache.ibatis.annotations.Param;
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 MyBatisTest {
   public static void main(String[] args) throws IOException {
       //读取mybatis配置文件
       String resource = "mybatis-config.xml";
       //获取mybatis配置文件的输入流
       InputStream is = Resources.getResourceAsStream(resource);
       //创建SqlSessionFactory对象
       SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
       //打开sqlSession对象
       SqlSession sqlSession =  factory.openSession();

       //获取对应的Mapper,让映射器通过命名空间和方法名称找到对应的SQL,发送给数据库执行后返回结果。
       User user = sqlSession.getMapper(UserMapper.class).login("zhanghua","userPassword");

       //看一下是否可以查到数据
       if (user != null) {
           System.out.println("登录成功");
       } else {
           System.out.println("登录失败");
       }

       //关闭sqlSession对象
       sqlSession.close();
   }
}
复制代码

最后

大家看完有什么不懂的可以在下方留言讨论,也可以关注我私信问我,我看到后都会回答的。同时谢谢大家的观看,觉得文章对你有帮助的话记得关注我点个赞支持一下!

相关推荐

得物可观测平台架构升级:基于GreptimeDB的全新监控体系实践

一、摘要在前端可观测分析场景中,需要实时观测并处理多地、多环境的运行情况,以保障Web应用和移动端的可用性与性能。传统方案往往依赖代理Agent→消息队列→流计算引擎→OLAP存储...

warm-flow新春版:网关直连和流程图重构

本期主要解决了网关直连和流程图重构,可以自此之后可支持各种复杂的网关混合、多网关直连使用。-新增Ruoyi-Vue-Plus优秀开源集成案例更新日志[feat]导入、导出和保存等新增json格式支持...

扣子空间体验报告

在数字化时代,智能工具的应用正不断拓展到我们工作和生活的各个角落。从任务规划到项目执行,再到任务管理,作者深入探讨了这款工具在不同场景下的表现和潜力。通过具体的应用实例,文章展示了扣子空间如何帮助用户...

spider-flow:开源的可视化方式定义爬虫方案

spider-flow简介spider-flow是一个爬虫平台,以可视化推拽方式定义爬取流程,无需代码即可实现一个爬虫服务。spider-flow特性支持css选择器、正则提取支持JSON/XML格式...

solon-flow 你好世界!

solon-flow是一个基础级的流处理引擎(可用于业务规则、决策处理、计算编排、流程审批等......)。提供有“开放式”驱动定制支持,像jdbc有mysql或pgsql等驱动,可...

新一代开源爬虫平台:SpiderFlow

SpiderFlow:新一代爬虫平台,以图形化方式定义爬虫流程,不写代码即可完成爬虫。-精选真开源,释放新价值。概览Spider-Flow是一个开源的、面向所有用户的Web端爬虫构建平台,它使用Ja...

通过 SQL 训练机器学习模型的引擎

关注薪资待遇的同学应该知道,机器学习相关的岗位工资普遍偏高啊。同时随着各种通用机器学习框架的出现,机器学习的门槛也在逐渐降低,训练一个简单的机器学习模型变得不那么难。但是不得不承认对于一些数据相关的工...

鼠须管输入法rime for Mac

鼠须管输入法forMac是一款十分新颖的跨平台输入法软件,全名是中州韵输入法引擎,鼠须管输入法mac版不仅仅是一个输入法,而是一个输入法算法框架。Rime的基础架构十分精良,一套算法支持了拼音、...

Go语言 1.20 版本正式发布:新版详细介绍

Go1.20简介最新的Go版本1.20在Go1.19发布六个月后发布。它的大部分更改都在工具链、运行时和库的实现中。一如既往,该版本保持了Go1的兼容性承诺。我们期望几乎所...

iOS 10平台SpriteKit新特性之Tile Maps(上)

简介苹果公司在WWDC2016大会上向人们展示了一大批新的好东西。其中之一就是SpriteKitTileEditor。这款工具易于上手,而且看起来速度特别快。在本教程中,你将了解关于TileE...

程序员简历例句—范例Java、Python、C++模板

个人简介通用简介:有良好的代码风格,通过添加注释提高代码可读性,注重代码质量,研读过XXX,XXX等多个开源项目源码从而学习增强代码的健壮性与扩展性。具备良好的代码编程习惯及文档编写能力,参与多个高...

Telerik UI for iOS Q3 2015正式发布

近日,TelerikUIforiOS正式发布了Q32015。新版本新增对XCode7、Swift2.0和iOS9的支持,同时还新增了对数轴、不连续的日期时间轴等;改进TKDataPoin...

ios使用ijkplayer+nginx进行视频直播

上两节,我们讲到使用nginx和ngixn的rtmp模块搭建直播的服务器,接着我们讲解了在Android使用ijkplayer来作为我们的视频直播播放器,整个过程中,需要注意的就是ijlplayer编...

IOS技术分享|iOS快速生成开发文档(一)

前言对于开发人员而言,文档的作用不言而喻。文档不仅可以提高软件开发效率,还能便于以后的软件开发、使用和维护。本文主要讲述Objective-C快速生成开发文档工具appledoc。简介apple...

macOS下配置VS Code C++开发环境

本文介绍在苹果macOS操作系统下,配置VisualStudioCode的C/C++开发环境的过程,本环境使用Clang/LLVM编译器和调试器。一、前置条件本文默认前置条件是,您的开发设备已...