详解Mybatis之自动映射 & 自定义映射问题

这篇具有很好参考价值的文章主要介绍了详解Mybatis之自动映射 & 自定义映射问题。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

编译软件:IntelliJ IDEA 2019.2.4 x64
操作系统:win10 x64 位 家庭版
Maven版本:apache-maven-3.6.3
Mybatis版本:3.5.6


详解Mybatis之自动映射 & 自定义映射问题,Mybatis,mybatis


一、Mybatis中的自动映射是什么?

Mybatis中的自动映射不是什么高大上的技术名词,而是我们使用Mybatis框架进行持久化层开发时常用select元素中的常见属性resultType它可以自动将数据库内表中的字段与类中的属性进行关联映射,故而得名。


二、Mybatis中的自定义映射是什么?

👉定义

自定义映射,简而言之,就是resultMap。Mybatis官方将resultMap称为结果映射,在为一些比如连接的复杂语句编写映射代码的时候,一份 resultMap 能够代替实现同等功能的数千行代码。

👉设计思想

对简单的语句做到零配置,对于复杂一点的语句,只需要描述语句之间的关系就行了。


三、为什么要使用自定义映射[resultMap]?

💡原因

它可以解决自动映射[resultType]解决不了的两类问题

哪两类问题?

  • 🍓多表连接查询时,需要返回多张表的结果集

    不信?请看如下测试案例

    测试案例:通过员工id获取员工信息及员工所属的部门信息

    ①准备数据

    详解Mybatis之自动映射 & 自定义映射问题,Mybatis,mybatis

    详解Mybatis之自动映射 & 自定义映射问题,Mybatis,mybatis

    ②在Mapper接口书写相应的方法

    代码示例如下:

    //通过员工id获取员工信息及员工所属的部门信息
    public List<Employee> showempByempId(int empId);
    

    ③在接口对应的映射文件中书写相应的sql

    代码示例如下:

    <select id="showempByempId" resultType="employee">
        SELECT
            e.`id`,
            e.`last_name`,
            e.`email`,
            e.`salary`,
            d.`dpt_id`,
            d.`dpt_name`
        FROM
            `tbl_employee` e, `tbl_department` d
        WHERE
            e.`dept_id`=d.`dpt_id`
        AND
            e.`id`=1;
    </select>
    

    ③测试

    @Test
    public void test01(){
    
        try {
            String resource = "mybatis-config.xml";
            InputStream inputStream = Resources.getResourceAsStream(resource);
            SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
    
            //通过SqlSessionFactory对象调用openSession();
            SqlSession sqlSession = sqlSessionFactory.openSession();
    
            //获取EmployeeMapper的代理对象
            EmployeeMapper employeeMapper = sqlSession.getMapper(EmployeeMapper.class);
    
            List<Employee> employees = employeeMapper.showempByempId(1);
            System.out.println(employees);
    
        } catch (IOException e) {
            e.printStackTrace();
        }
    
    }
    

    详解Mybatis之自动映射 & 自定义映射问题,Mybatis,mybatis

    🙋 为什么员工所属的部门信息查不出来?

    🙇 原因

    书写的sql涉及到多表查询,映射文件中相应select子标签的属性为resultType。该属性不支持映射多表查询后的结果集,需要用到自定义映射来解决该问题

  • 🍓单表查询时,不支持驼峰式自动映射【如果不想为字段定义别名】

自定义映射【resultMap】:自动映射解决不了的问题,可以交给自定义映射

👇 注意

resultType与resultMap只能同时使用一个


四、自定义映射[resultMap]可以适用哪些场景?

4.1 resultMap之级联映射

🙋 何为级联映射?

👇 答曰

级联映射是指在保存主对象时,将关联的对象也一起保存到数据库中。例如,对于一对多或者多对一、多对多等关系对象时,当保存某个一对象时,与这个依赖的对象都应该自动保存或更新。比如:部门和员工表,一对多关系,当保存部门数据时,和部门有关联的员工表也同时保存。

用法案例

基于第三节中的案例,在映射文件中使用resultMap来解决多表查询后结果集中dept值为null的问题

代码示例如下:

①在在映射文件中使用自定义映射

<resultMap id="empAnddeptResultMap" type="employee">
    <!--  column:返回的结果集中的字段  property:返回值类型(employee)中的属性,要映射的类      -->
    <!--  id属性是定义主键字段与属性之间的关联关系      -->
    <id column="id" property="id"></id>

    <!--  result属性是定义非主键字段与属性之间的关联关系      -->
    <result column="last_name" property="lastName"></result>
    <result column="email" property="email"></result>
    <result column="salary" property="salary"></result>
    <result column="dpt_id" property="dept.deptId"></result>
    <result column="dpt_name" property="dept.deptName"></result>
</resultMap>




<select id="showempByempId" resultMap="empAnddeptResultMap">
    SELECT
        e.`id`,
        e.`last_name`,
        e.`email`,
        e.`salary`,
        d.`dpt_id`,
        d.`dpt_name`
    FROM
        `tbl_employee` e, `tbl_department` d
    WHERE
        e.`dept_id`=d.`dpt_id`
    AND
        e.`id`=1;
</select>

②测试运行

详解Mybatis之自动映射 & 自定义映射问题,Mybatis,mybatis

4.1.1 级联映射之association映射[1:1]

👉特点

解决一对一的关联关系

👉用法案例

基于4.1小结中的案例,对映射文件中的sql部分进行association映射的改写,观察效果

代码示例如下:

①对映射文件中的sql部分进行association映射的改写

<resultMap id="empAnddeptResultMap" type="employee">
    <!--  column:返回的结果集中的字段  property:返回值类型(employee)中的属性,要映射的类      -->
    <!--  id属性是定义主键字段与属性之间的关联关系      -->
    <id column="id" property="id"></id>

    <!--  result属性是定义非主键字段与属性之间的关联关系      -->
    <result column="last_name" property="lastName"></result>
    <result column="email" property="email"></result>
    <result column="salary" property="salary"></result>
  

    <!--  javaType: 用来指定某个属性(dept)或字段在 Java 代码中所对应的具体数据类型 (mybatis.pojo.Dept)    -->
    <!--  dept属性指的是employee对象中的属性    -->
    <association property="dept" javaType="mybatis.pojo.Dept">
        <id column="dpt_id" property="deptId"></id>
        <result column="dpt_name" property="deptName"></result>
    </association>


</resultMap>


<select id="showempByempId" resultMap="empAnddeptResultMap">
    SELECT
        e.`id`,
        e.`last_name`,
        e.`email`,
        e.`salary`,
        d.`dpt_id`,
        d.`dpt_name`
    FROM
        `tbl_employee` e, `tbl_department` d
    WHERE
        e.`dept_id`=d.`dpt_id`
    AND
        e.`id`=1;
</select>

②测试运行

详解Mybatis之自动映射 & 自定义映射问题,Mybatis,mybatis

4.1.2 级联映射之collection映射[1:m]

👉特点

解决一对多的关联关系

👉用法案例

根据部门编号查询对应的部门信息,然后拿着部门编号去员工表里去找所属的员工信息(此时部门与员工是一对多的关系)

代码示例如下:

准备数据

详解Mybatis之自动映射 & 自定义映射问题,Mybatis,mybatis

①在DeptMapper接口书写相应的方法

//根据部门编号查询对应的部门信息,然后拿着部门编号去员工表里去找所属的员工信息(一对多)
public Dept showEmployeesByDeptId(int deptId);

②在在DeptMapper接口对应的映射文件中书写相应的sql

<!-- collection property="employees" ofType="mybatis.pojo.Employee" -> 在Dept类中名为employees的集合中存储的元素类型  -->
    <resultMap id="showEmployeesByDeptIdResultMap" type="dept">
        <id property="deptId" column="dpt_id"></id>
        <result property="deptName" column="dpt_name"></result>

        <collection property="employees" ofType="mybatis.pojo.Employee">
            <!--  id属性是定义主键字段与属性之间的关联关系      -->
            <id column="id" property="id"></id>

            <!--  result属性是定义非主键字段与属性之间的关联关系      -->
            <result column="last_name" property="lastName"></result>
            <result column="email" property="email"></result>
            <result column="salary" property="salary"></result>
        </collection>


    </resultMap>

    <select id="showEmployeesByDeptId" resultMap="showEmployeesByDeptIdResultMap">
        SELECT
            e.`id`,
            e.`last_name`,
            e.`email`,
            e.`salary`,
            d.`dpt_id`,
            d.`dpt_name`
        FROM
            `tbl_employee` e, `tbl_department` d
        WHERE
            e.`dept_id`=d.`dpt_id`
        AND
            d.`dpt_id`=#{dptId};
    </select>

③测试

@Test
public void test04(){

    try {
        String resource = "mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

        //通过SqlSessionFactory对象调用openSession();
        SqlSession sqlSession = sqlSessionFactory.openSession();

        //获取EmployeeMapper的代理对象
        DeptMapper deptMapper = sqlSession.getMapper(DeptMapper.class);
        
        //查询部门编号为1的部门信息,并得到所属员工的所有员工信息
        Dept dept = deptMapper.showEmployeesByDeptId(1);
        System.out.println(dept);

    } catch (IOException e) {
        e.printStackTrace();
    }

}

详解Mybatis之自动映射 & 自定义映射问题,Mybatis,mybatis

4.2 总结ResultMap中的相关标签及属性

  • resultMap标签自定义映射标签

    • id属性定义唯一标识
    • type属性设置映射类型
  • resultMap子标签

    • id标签定义主键字段与属性关联关系

    • result标签定义非主键字段与属性关联关系

      • column属性定义表中字段名称
      • property属性定义类中属性名称
    • associationi标签定义一对一的关联关系

      • property属性定义关联关系属性
      • javaType属性定义关联关系属性的类型
      • select属性设置分步查询SQL全路径
      • colunm属性设置分步查询SQL中需要参数
      • fetchType:设置局部延迟加载【懒加载】
    • collection标签定义一对多的关联关系

      • property属性定义关联关系属性
      • ofType属性定义关联关系属性类型
      • select属性设置分步查询SQL全路径
      • colunm属性设置分步查询SQL中需要参数
      • fetchType:设置局部延迟加载【懒加载】是否开启

4.3 分步查询

🙋 为什么使用分步查询【分步查询优势】?

将多表连接查询,改为【分步单表查询】,从而提高程序运行效率

4.3.1 一对一的关联关系

👉用法案例

使用分步查询实现通过员工id获取员工信息及员工所属的部门信息,比如说1.通过员工id获取员工信息,2.通过员工信息中的部门id获得所属部门得信息(员工与部门是一对一的关系,即一个员工只能归属一个部门)

代码示例如下:

①在EmployeeMapper接口中定义实现通过员工id获取员工信息的方法

//使用分步查询实现通过员工id获取员工信息及员工所属的部门信息
//1.通过员工id获取员工信息
//2.通过员工信息中的部门id获得所属部门得信息
public Employee selectEmpByempId(int empId);

②在DeptMapper接口中定义实现通过从查出来的员工信息中的部门编号去查所属部门信息

//通过部门id查询所属部门得信息
public Dept selectDeptByDeptId(int deptId);

③在EmployeeMapper接口对应的映射文件书写相应的sql

 <resultMap id="selectEmpByempIdResultMap" type="mybatis.pojo.Employee">
        <id property="id" column="id"></id>
        <result property="lastName" column="last_name"></result>
        <result property="email" column="email"></result>
        <result property="salary" column="salary"></result>

<!--  column="deptId"  设置分步查询SQL中需要得参数dept_Id;将此值传入到mybatis.mapper.DeptMapper中的selectDeptByDeptId()方法中     -->
        <association property="dept"
                     select="mybatis.mapper.DeptMapper.selectDeptByDeptId"
                     column="dept_Id"   >

        </association>

    </resultMap>




    <select id="selectEmpByempId" resultMap="selectEmpByempIdResultMap">
        SELECT
            `id`,
            `last_name`,
            `email`,
            `salary`,
            `dept_id`
        FROM
            `tbl_employee`
       WHERE
            `id`=#{empId};

    </select>

④在DeptMapper接口对应的映射文件中书写相应的sql

<resultMap id="selectDeptByDeptIdResultMap" type="dept">
    <id property="deptId" column="dpt_Id"></id>
    <result property="deptName" column="dpt_name"></result>
</resultMap>

<select id="selectDeptByDeptId" resultMap="selectDeptByDeptIdResultMap">
    select
        dpt_Id,
        dpt_name
    from
        tbl_department
    where
        dpt_Id=#{dptId}
</select>

⑤测试

@Test
public void test02(){

    try {
        String resource = "mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

        //通过SqlSessionFactory对象调用openSession();
        SqlSession sqlSession = sqlSessionFactory.openSession();

        //获取EmployeeMapper的代理对象
        EmployeeMapper employeeMapper = sqlSession.getMapper(EmployeeMapper.class);

        Employee employee = employeeMapper.selectEmpByempId(2);
        System.out.println(employee);

    } catch (IOException e) {
        e.printStackTrace();
    }

}

详解Mybatis之自动映射 & 自定义映射问题,Mybatis,mybatis

4.3.2 一对多的关联关系

👉用法案例

通过部门id获取部门信息,及部门所属员工信息【使用分步查询来实现】,其中按1.通过部门id获取部门信息;2.通过部门id获取员工信息等这两个步骤完成分步查询

代码示例如下:

①在DeptMapper接口中书写查询通过部门id获取部门信息的方法

//通过部门id获取部门信息
public Dept showEmployeesByDeptIdBetter(int deptId);

②在DeptMapper接口对应的映射文件中书写相应的sql

<!--  type="dept" 设置映射类型为dept,为什么不是dept类的全称,因为我在配置文件给它起了别名  -->
    <resultMap id="showEmployeesByDeptIdBetterResultMap" type="dept">
        <id property="deptId" column="dpt_id"></id>
        <result property="deptName" column="dpt_name"></result>

        <collection property="employees"
                    select="mybatis.mapper.EmployeeMapper#selectEmployeeByempId"
                    column="dpt_Id">

        </collection>
    </resultMap>

    <select id="showEmployeesByDeptIdBetter" resultMap="showEmployeesByDeptIdBetterResultMap">
        SELECT
            `dpt_id`,
            `dpt_name`
        FROM
            `tbl_department`
        WHERE
            `dpt_id`=#{dptId};

    </select>

③在EmployeeMapper接口中书写查询通过部门id获取所属员工信息的方法

//通过部门id查询对应的员工信息
public Employee selectEmployeeByempId(int empId);

④在EmployeeMapper接口对应的映射文件中书写相应的sql

<select id="showEmployeesByDeptIdBetter" resultMap="showEmployeesByDeptIdBetterResultMap">
    SELECT
        `dpt_id`,
        `dpt_name`
    FROM
        `tbl_department`
    WHERE
        `dpt_id`=#{dptId};

</select>

⑤测试

@Test
//测试分步查询版(根据部门编号查询对应的部门信息,然后拿着部门编号去员工表里去找所属的员工信息)
public void test05(){

    try {
        String resource = "mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

        //通过SqlSessionFactory对象调用openSession();
        SqlSession sqlSession = sqlSessionFactory.openSession();

        //获取EmployeeMapper的代理对象
        DeptMapper deptMapper = sqlSession.getMapper(DeptMapper.class);
        Dept dept = deptMapper.showEmployeesByDeptId(1);
        System.out.println(dept);

    } catch (IOException e) {
        e.printStackTrace();
    }

}

详解Mybatis之自动映射 & 自定义映射问题,Mybatis,mybatis

4.3.3 扩展

如果使用分步查询时,需要传递给调用的查询中多个参数,则需要将多个参数封装成 Map来进行传递,语法如下:{k1=v1,k2=v2}


五、Mybatis如何使用延迟加载【懒加载】?

🙋什么是延迟加载?

需要时加载,不需要暂时不加载,如何理解?举个生活中的例子,就好比当你非常饥饿时,才会去吃饭

👉优势

可以提高程序运行效率

👉语法

🚀①全局设置

在核心配置文件中这样写,示例代码如下

<settings>
    <!--    开启驼峰命名自动映射    -->
    <setting name="mapUnderscoreToCamelCase" value="true"/>

    <!--  开启全局延迟加载模式      -->
    <setting name="lazyLoadingEnabled" value="true"/>
    <!--  关闭按需延迟加载模式,在3.4.2版本及以后该步骤可省略      -->
    <setting name="aggressiveLazyLoading" value="false"/>
</settings>

👉用法案例

在核心配置文件开启全局延迟加载模式,借助8.6小结中的案例代码,演示全局延迟加载模式的效果

代码示例如下:

测试运行如下

try {
    String resource = "mybatis-config.xml";
    InputStream inputStream = Resources.getResourceAsStream(resource);
    SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

    //通过SqlSessionFactory对象调用openSession();
    SqlSession sqlSession = sqlSessionFactory.openSession();

    //获取EmployeeMapper的代理对象
    EmployeeMapper employeeMapper = sqlSession.getMapper(EmployeeMapper.class);

    Employee employee = employeeMapper.selectEmpByempId(2);
    System.out.println("employee.getLastName() = "+employee.getLastName());
    System.out.println("--------------------------------------");
    System.out.println("employee.getDept() = "+employee.getDept());

} catch (IOException e) {
    e.printStackTrace();
}

详解Mybatis之自动映射 & 自定义映射问题,Mybatis,mybatis

🚀②局部设置

  • fetchType
    • eager关闭局部延迟加载
    • lazy开启局部延迟加载

👉用法案例

在上述案例中EmployeeMapper接口对应的映射文件里属性id的值为"selectEmpByempId"的sql设置关闭延迟加载(已经设置了全局延迟加载模式,这里再开启局部延迟加载,效果不明显,遂采用关闭局部延迟加载测试效果)

代码示例如下:

    <resultMap id="selectEmpByempIdResultMap" type="mybatis.pojo.Employee">
        <id property="id" column="id"></id>
        <result property="lastName" column="last_name"></result>
        <result property="email" column="email"></result>
        <result property="salary" column="salary"></result>

<!--  column="deptId"  设置分步查询SQL中需要得参数dept_Id;将此值传入到mybatis.mapper.DeptMapper中的selectDeptByDeptId()方法中     -->
        <!--   fetchType="lazy" 为此方法设置局部延迟加载                   -->
        <association property="dept"
                     select="mybatis.mapper.DeptMapper.selectDeptByDeptId"
                     column="dept_Id"
               
                     fetchType="lazy"   >

        </association>

    </resultMap>

    <select id="selectEmpByempId" resultMap="selectEmpByempIdResultMap">
        SELECT
            `id`,
            `last_name`,
            `email`,
            `salary`,
            `dept_id`
        FROM
            `tbl_employee`
       WHERE
            `id`=#{empId};

    </select>

运行测试如下

详解Mybatis之自动映射 & 自定义映射问题,Mybatis,mybatis文章来源地址https://www.toymoban.com/news/detail-611382.html


到了这里,关于详解Mybatis之自动映射 & 自定义映射问题的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • application.yml文件中开启mybatis自动驼峰映射

    如果不开启映射 在使用BaseMapper 和Iservice封装的方法时 会报错 如果在Mapper.xml文件中自己写sql语句 在selsect* 或者其他字段名自己指定清楚的情况下 不会报错 但同样无法正确返回数据 道理很简单 因为数据库数据 写不到java的属性名里 只是查询能查到 不会报错 sql查询默认查询

    2024年02月14日
    浏览(64)
  • Mybatis使用collection映射一对多查询分页问题

    场景:页面展示列表,需要查询多的字段,和一的字段。并且还要分页。 这时候直接想到的是手写sql。 原来的sql 。 正常查询tags有两条。加上分页条件,多的一端只有一条数据。 修改之后的sq。满足分页正常展示多的一端。

    2024年02月15日
    浏览(35)
  • mybatis实现CRUD详解(使用mapper映射文件实现增删改查)

    创建maven项目:项目结构如图所示 准备数据库表: 准备pom.xml所需的依赖: 编写核心配置文件加载所需要的资源 编写config.xml文件 创建工厂连接数据处理工具SqlSessionUtil.java SqlSessionUtil.java 创建学生实体类对象Student.java 1、查询所有学生信息: 创建接口StudentDao.java:向其中添加

    2023年04月23日
    浏览(44)
  • 解决使用MyBatis Plus自动映射功能中数据库表与实体类不匹配导致映射失败的深度探索与分布式实践

    摘要:在开发Java应用程序过程中,使用MyBatis Plus自动映射功能可以大大简化数据访问层的开发。然而,当数据库表与实体类的字段与属性没有对应关系时,可能会导致映射失败。本篇文章将深入探索这一问题,并结合Java深度和分布式实践,提供解决方案。 在开发基于Java的应

    2024年02月04日
    浏览(96)
  • 使用Mybatis自定义插件实现不侵入业务的公共参数自动追加

    后台业务开发的过程中,往往会遇到这种场景:需要记录每条记录产生时间、修改时间、修改人及添加人,在查询时查询出来。 以往的做法通常是手动在每个业务逻辑里耦合上这么一块代码,也有更优雅一点的做法是写一个拦截器,然后在Mybatis拦截器中为实体对象中的公共

    2024年02月04日
    浏览(42)
  • Springboot 自定义 Mybatis拦截器,实现 动态查询条件SQL自动组装拼接(玩具)

    ps:最近在参与3100保卫战,战况很激烈,刚刚打完仗,来更新一下之前写了一半的博客。 该篇针对日常写查询的时候,那些动态条件sql 做个简单的封装,自动生成(抛砖引玉,搞个小玩具,不喜勿喷)。 来看看我们平时写那些查询,基本上都要写的一些动态sql:   一个字段

    2024年02月12日
    浏览(49)
  • Mybatis/Mybatis-Plus驼峰式命名映射

    目录 一、mybatis驼峰式命名 二、mybatisPlus默认开启驼峰命名映射 方法一: 使用前提:数据库表设计按照规范“字段名中各单词使用下划线\\\"_\\\"划分”; 使用好处:省去mapper.xml文件中繁琐编写表字段列表与表实体类属性的映射关系,即resultMap。 示例: 方法二: mybatis-config.xml文

    2024年02月14日
    浏览(48)
  • 【Mybatis】深入学习MyBatis:概述、主要特性以及配置与映射

    🍎 个人博客: 个人主页 🏆 个人专栏:   Mybatis    ⛳️   功不唐捐,玉汝于成 目录 前言 正文 一、概述 MyBatis简介 主要特性 1. 动态SQL 2.结果映射 3 .插件机制 二、MyBatis配置文件 1.配置文件结构 数据库连接信息 全局配置 映射器扫描 2.SQL映射文件 SQL语句定义 参数映射和

    2024年02月04日
    浏览(56)
  • 【mybatis-plus实体类复杂对象字段json自动相互转换,以及自定义字段类型解析器】

    引言: mybatis-plus集合对象字段json如何自动进行相互的转换? 怎样在使用mybatis-plus操作数据表的时候自动对实体类属性进行自动解析? 我们平时在做开发的时候,会遇到一个字段保存json串的情况。一般情况下mybatis-plus在做插入/更新之前将对象手动转换成json串,查询要用的时

    2023年04月13日
    浏览(103)
  • 【MyBatis】1、MyBatis 核心配置文件、多表查询、实体映射文件 ......

    SSM( S pring、 S pringMVC、 M yBatis) Apache Shiro SpringBoot 事务 :若将 N 个 数据库操作 (CRUD)放到同一个事务中,则这 N 个数据库操作最终要么全都生效,要么全都不生效 🍀 开启事务【 START TRANSACTION 】 🍀 回滚事务:若事务中的某个数据库操作失败,其他所有数据库操作都需要

    2024年02月08日
    浏览(80)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包