mybatis动态SQL-sql片段

news2024/9/28 5:33:18

1、建库建表

create database `mybatis-example`;
use `mybatis-example`;
create table emp
(
    empNo   varchar(40),
    empName varchar(100),
    sal int,
    deptno varchar(10)
);
insert into emp values('e001','张三',8000,'d001');
insert into emp values('e002','李四',9000,'d001');
insert into emp values('e003','王五',10000,'d001');
insert into emp values('e004','赵六',11000,'d002');
insert into emp values('e005','田七',12000,'d002');
insert into emp values('e006','周八',13000,'d003');
insert into emp values('e007','吴九',14000,'d004');
insert into emp values('e008','郑十',15000,'d004');
insert into emp values('d8f9b794-95ba-11ee-ab75-84a93ea22bfb','张三丰',16000,'d001');

2、pom.xml

    <dependencies>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
        </dependency>
 
        <!-- MySQL驱动 mybatis底层依赖jdbc驱动实现,本次不需要导入连接池,mybatis自带! -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
 
        <!--junit5测试-->
        <dependency>
            <groupId>org.junit.jupiter</groupId>
            <artifactId>junit-jupiter-api</artifactId>
        </dependency>
 
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
 
        <!-- 日志 , 会自动传递slf4j门面-->
        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-classic</artifactId>
        </dependency>
    </dependencies>

3、Emp.java

package com.atguigu.mybatis.mapper;
import com.atguigu.mybatis.pojo.Emp;
import org.apache.ibatis.annotations.Param;
import java.util.List;
public interface EmpMapper {
    //1.演示where-if标签
    List<Emp> getEmpList(Emp emp);
 
    //2、演示set标签
    void updateEmp(Emp emp);
 
    //3、演示trim标签
    List<Emp> getEmpList2(Emp emp);
 
    //4、演示choose/when/otherwise标签
    List<Emp> getEmpList3(Emp emp);
 
    //5、演示foreach标签
    List<Emp> getEmpList4(@Param("empNoList") List<String> empNoList);
}

5、mybatis-config.xml

<?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>
 
    <!-- 具体配置 -->
    <!-- 从org.apache.ibatis.session.Configuration类中可以查看能使用的配置项 -->
    <!-- 将mapUnderscoreToCamelCase属性配置为true,表示开启自动映射驼峰式命名规则 -->
    <!-- 规则要求数据库表字段命名方式:单词_单词 -->
    <!-- 规则要求Java实体类属性名命名方式:首字母小写的驼峰式命名 -->
    <settings>
        <setting name="lazyLoadingEnabled" value="true"/>
        <setting name="autoMappingBehavior" value="FULL"/>
        <setting name="mapUnderscoreToCamelCase" value="true"/>
    </settings>
 
    <typeAliases>
        <!--<typeAlias type="com.atguigu.mybatis.pojo.Employee" alias="emp"/>-->
        <package name="com.atguigu.mybatis.pojo"/>
    </typeAliases>
 
    <!-- environments表示配置Mybatis的开发环境,可以配置多个环境,在众多具体环境中,使用default属性指定实际运行时使用的环境。default属性的取值是environment标签的id属性的值。 -->
    <environments default="development">
        <!-- environment表示配置Mybatis的一个具体的环境 -->
        <environment id="development">
            <!-- Mybatis的内置的事务管理器 -->
            <transactionManager type="JDBC"/>
            <!-- 配置数据源 -->
            <dataSource type="POOLED">
                <!-- 建立数据库连接的具体信息 -->
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/mybatis-example"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>
 
    <mappers>
        <!-- Mapper注册:指定Mybatis映射文件的具体位置 -->
        <!-- mapper标签:配置一个具体的Mapper映射文件 -->
        <!-- resource属性:指定Mapper映射文件的实际存储位置,这里需要使用一个以类路径根目录为基准的相对路径 -->
        <!-- 对Maven工程的目录结构来说,resources目录下的内容会直接放入类路径,所以这里我们可以以resources目录为基准 -->
        <mapper resource="mappers/EmpMapper.xml"/>
    </mappers>
 
</configuration>

6、mappers/EmpMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- namespace等于mapper接口类的全限定名,这样实现对应 -->
<mapper namespace="com.atguigu.mybatis.mapper.EmpMapper">

    <select id="getEmpList" resultType="Emp">
        select * from emp
        <where>
            <if test="empNo!= null">
                empNo=#{empNo}
            </if>
            <if test="empName!= null">
                and empName=#{empName}
            </if>
            <if test="sal!=null">
                and sal &lt; #{sal}
            </if>
            <if test="deptno!=null">
                and deptno=#{deptno}
            </if>
        </where>
        <!--
                select * from emp
                select * from emp WHERE empNo=?
                select * from emp WHERE sal < ?
                select * from emp WHERE empName=?
                select * from emp WHERE deptno=?
                select * from emp WHERE empNo=? and sal < ?
                select * from emp WHERE empNo=? and empName=? and sal < ?
                select * from emp WHERE empNo=? and empName=? and sal < ? and deptno=?
        -->
    </select>

    <update id="updateEmp">
        update emp
        <set>
            <if test="empName!=null">
                empName=#{empName},
            </if>
            <if test="sal!=null">
                sal=#{sal},
            </if>
            <if test="deptno!=null">
                deptno=#{deptno}
            </if>
        </set>
        where empNo=#{empNo}
        <!--
               update emp SET empName=?, sal=?, deptno=? where empNo=?
               update emp SET empName=? where empNo=?
               update emp                    where empNo=?
        -->
    </update>

    <select id="getEmpList2" resultType="Emp">
        select * from emp
        <trim prefix="where" suffix=";" prefixOverrides="or|and" suffixOverrides="or">
            <if test="empNo!=null">
                or empNo=#{empNo} or
            </if>
            <if test="empName!=null">
                or empName=#{empName} or
            </if>
            <if test="sal!=null">
                or sal &lt; #{sal} or
            </if>
            <if test="deptno!=null">
                or deptno=#{deptno} or
            </if>
        </trim>
    </select>

    <select id="getEmpList3" resultType="Emp">
        select * from emp where
        <choose>
            <when test="empNo!=null">
                empNo=#{empNo}
            </when>
            <when test="empName!=null">
                 empName=#{empName}
            </when>
            <when test="sal!=null">
                 sal &lt; #{sal}
            </when>
            <when test="deptno!=null">
                 deptno=#{deptno}
            </when>
            <otherwise>
                1=1
            </otherwise>
        </choose>
    </select>

    <select id="getEmpList4" resultType="Emp">
        <include refid="allColumns"></include>
        from emp where empNo in
        <foreach collection="empNoList" item="employeeNumber" open="(" close=")" separator=",">
            #{employeeNumber}
        </foreach>
    </select>

    <sql id="allColumns">
        select empNo,empName,sal,deptno,'China' as 'address'
    </sql>
</mapper>

7、logback.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true">
    <!-- 指定日志输出的位置,ConsoleAppender表示输出到控制台 -->
    <appender name="STDOUT"
              class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <!-- 日志输出的格式 -->
            <!-- 按照顺序分别是:时间、日志级别、线程名称、打印日志的类、日志主体内容、换行 -->
            <pattern>[%d{HH:mm:ss.SSS}] [%-5level] [%thread] [%logger] [%msg]%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>
 
    <!-- 设置全局日志级别。日志级别按顺序分别是:TRACE、DEBUG、INFO、WARN、ERROR -->
    <!-- 指定任何一个日志级别都只打印当前级别和后面级别的日志。 -->
    <root level="DEBUG">
        <!-- 指定打印日志的appender,这里通过“STDOUT”引用了前面配置的appender -->
        <appender-ref ref="STDOUT" />
    </root>
 
    <!-- 根据特殊需求指定局部日志级别,可以是包名或全类名。 -->
    <logger name="com.atguigu.mybatis" level="DEBUG" />
</configuration>

8、MybatisTest.java

package mybatis;
import com.atguigu.mybatis.mapper.EmpMapper;
import com.atguigu.mybatis.pojo.Emp;
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 org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import java.io.IOException;
import java.io.InputStream;
import java.util.Arrays;
public class MybatisTest {

    SqlSessionFactory sqlSessionFactory;
    SqlSession sqlSession;
    EmpMapper empMapper;

    @BeforeEach
    public void setup() throws IOException {
        // 获取资源流,读取"mybatis-config.xml"文件
        InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
        // 使用资源流创建SqlSessionFactory
        sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        // 使用SqlSessionFactory打开一个Session
        sqlSession = sqlSessionFactory.openSession();
        //基于Mapper接口编程
        empMapper=sqlSession.getMapper(EmpMapper.class);
    }

    // 在每个测试用例之后执行的清理方法
    @AfterEach
    public void teardown() {
        sqlSession.commit();  // 提交事务
        sqlSession.close();  // 关闭SqlSession
    }

    @Test
    public void selectWhereIFTest() {
        /**
         * 1、所有条件都不满足
         */
        Emp emp = new Emp();
        empMapper.getEmpList(emp).forEach(System.out::println);//select * from emp
        //Emp(empNo=e001, sal=8000, empName=张三, deptno=d001)
        //Emp(empNo=e002, sal=9000, empName=李四, deptno=d001)
        //Emp(empNo=e003, sal=10000, empName=王五, deptno=d001)
        //Emp(empNo=e004, sal=11000, empName=赵六, deptno=d002)
        //Emp(empNo=e005, sal=12000, empName=田七, deptno=d002)
        //Emp(empNo=e006, sal=13000, empName=周八, deptno=d003)
        //Emp(empNo=e007, sal=14000, empName=吴九, deptno=d004)
        //Emp(empNo=e008, sal=15000, empName=郑十, deptno=d004)
        //Emp(empNo=d8f9b794-95ba-11ee-ab75-84a93ea22bfb, sal=16000, empName=张三丰, deptno=d001)

        /**
         * 2、一个条件满足
         */
        Emp emp1 = new Emp();
        emp1.setEmpNo("e002");
        empMapper.getEmpList(emp1).forEach(System.out::println);//select * from emp WHERE empNo=?
        //Emp(empNo=e002, sal=9000, empName=李四, deptno=d001)

        Emp emp2 = new Emp();
        emp2.setSal(11000);
        empMapper.getEmpList(emp2).forEach(System.out::println);//select * from emp WHERE sal < ?
        //Emp(empNo=e001, sal=8000, empName=张三, deptno=d001)
        //Emp(empNo=e002, sal=9000, empName=李四, deptno=d001)
        //Emp(empNo=e003, sal=10000, empName=王五, deptno=d001)

        Emp emp3 = new Emp();
        emp3.setEmpName("张三丰");
        empMapper.getEmpList(emp3).forEach(System.out::println);//select * from emp WHERE empName=?
        //Emp(empNo=d8f9b794-95ba-11ee-ab75-84a93ea22bfb, sal=16000, empName=张三丰, deptno=d001)

        Emp emp4 = new Emp();
        emp4.setDeptno("d001");
        empMapper.getEmpList(emp4).forEach(System.out::println);//select * from emp WHERE deptno=?
        //Emp(empNo=e001, sal=8000, empName=张三, deptno=d001)
        //Emp(empNo=e002, sal=9000, empName=李四, deptno=d001)
        //Emp(empNo=e003, sal=10000, empName=王五, deptno=d001)
        //Emp(empNo=d8f9b794-95ba-11ee-ab75-84a93ea22bfb, sal=16000, empName=张三丰, deptno=d001)

        /**
         * 2、两个条件满足
         */
        Emp emp5 = new Emp();
        emp5.setEmpNo("e002");
        emp5.setSal(11000);
        empMapper.getEmpList(emp5).forEach(System.out::println);//select * from emp WHERE empNo=? and sal <?
        //Emp(empNo=e002, sal=9000, empName=李四, deptno=d001)

        /**
         * 3、三个条件都满足,以次类推
         */
        Emp emp6 = new Emp();
        emp6.setEmpNo("e002");
        emp6.setSal(11000);
        emp6.setEmpName("张三丰");
        empMapper.getEmpList(emp6).forEach(System.out::println);//select * from emp WHERE empNo=? and empName=? and sal < ?


        /**
         * 4、全部条件满足
         */
        Emp emp100 = new Emp("e001",8001,"张三","d001");
        empMapper.getEmpList(emp100).forEach(System.out::println);//select * from emp WHERE empNo=? and empName=? and sal < ? and deptno=?
        //Emp(empNo=e001, sal=8000, empName=张三, deptno=d001)
    }

    @Test
    public void updateSetIfTest() {

        /**
         * 1、所有条件都满足
         */
        Emp emp = new Emp("e001",4000,"张三","d001");
        empMapper.updateEmp(emp);//update emp SET empName=?, sal=?, deptno=? where empNo=?

        /**
         * 2、部分条件满足
         */
        Emp emp1 = new Emp();
        emp1.setEmpNo("e002");
        emp1.setEmpName("张无忌");
        empMapper.updateEmp(emp1);//update emp SET empName=? where empNo=?

        /**
         * 3、所有条件都不满足,报错SQLSyntaxErrorException
         */
        Emp emp2 = new Emp();
        emp2.setEmpNo("e003");
        empMapper.updateEmp(emp2);

    }

    @Test
    public void trimTest() {
        Emp emp = new Emp();
        empMapper.getEmpList2(emp).forEach(System.out::println);//select * from emp

        Emp emp1 = new Emp();
        emp1.setEmpNo("e001");
        empMapper.getEmpList2(emp1).forEach(System.out::println);//select * from emp where empNo=? ;
    }

    @Test
    public void chooseWhenTest() {

        Emp emp1 = new Emp();
        empMapper.getEmpList3(emp1).forEach(System.out::println);//select * from emp where 1=1

        Emp emp2 = new Emp();
        emp2.setEmpNo("e001");
        empMapper.getEmpList3(emp2).forEach(System.out::println);//select * from emp where empNo=?

        Emp emp3 = new Emp();
        emp3.setEmpNo("e002");
        emp3.setEmpNo("李四");
        empMapper.getEmpList3(emp3).forEach(System.out::println);//select * from emp where empNo=?
    }

    @Test
    public void foreachTest() {
        Emp emp = new Emp();
        empMapper.getEmpList4(Arrays.asList("e001","e002")).forEach(System.out::println);
        //select * from emp where empNo in ( ? , ? )
        //Emp(empNo=e001, sal=4000, empName=张三, deptno=d001)
        //Emp(empNo=e002, sal=9000, empName=李四, deptno=d001)
    }
}

 9、sql片段的作用

  • SQL片段的作用是将重复的SQL语句抽取出来,放到<sql>标签中,可以进行复用。这个SQL片段类似于代码片段,可以将部分SQL语句打包或封装到一个SQL片段里。使用SQL片段可以减少SQL语句冗余,便于SQL语句的维护和管理,类似于Java的方法,可以复用SQL语句。
  • SQL片段的作用是在SQL查询语句中使用,用于实现特定的功能或逻辑。SQL片段可以是一个表达式、函数、操作符、条件语句、连接语句等,它们可以在SQL查询中被引用和执行。使用SQL片段可以简化复杂的查询逻辑、重用代码、提高查询性能以及使查询语句更加可读。例如,可以使用SQL片段来实现计算字段、过滤数据、排序结果等操作。
  • SQL片段的存在是为了提高代码的可维护性和重用性。通过将重复的SQL语句片段抽象和封装,可以减少代码中的冗余,使得代码更加简洁和易于管理。同时,当需要修改或扩展SQL语句时,只需要修改或添加相应的片段,而不需要对整个SQL语句进行修改,从而提高了代码的灵活性和可扩展性。此外,SQL片段还可以提高代码的可读性和可维护性,使得代码更加清晰和易于理解。

SQL片段是SQL代码的一个部分,它可以在大型SQL查询或复杂的数据库操作中使用。以下是为什么要使用SQL片段的一些原因:

  1. 重用性:SQL片段可以在多个查询中重复使用,避免重复编写相同的代码。这有助于简化代码并提高开发效率。

  2. 可维护性:通过将代码逻辑分解为片段,可以更容易地理解和维护。如果需要进行更改或修复,只需更改片段而不是整个查询。

  3. 可读性:较长或复杂的SQL查询可能会变得难以理解。将其分解为片段可以提高代码的可读性,易于阅读和理解。

  4. 灵活性:SQL片段允许开发人员根据需要组合不同的代码块,以创建适应特定需求的查询。这提供了更大的灵活性和可定制性。

  5. 性能优化:通过使用SQL片段,可以更容易地对查询进行优化。可以通过调整和优化片段,以提高整个查询的性能。

总之,SQL片段提供了一种组织和管理SQL代码的有效方式,可以提高开发效率、可维护性和可读性,并允许进行更好的性能优化。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1309937.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

用CHAT分析问题的作用

问CHAT&#xff1a;电网数据中心的数据生命周期管理的管理平台是数据资产目录管理平台&#xff0c;简述一下它的作用。 CHAT回复&#xff1a;数据资产目录管理平台 (Data Catalog Management Platform) 是电网数据中心对于数据生命周期管理的重要工具。 1. 提供统一视图&#…

量子计算挑战赛启动!空中客车公司和宝马集团联手发起

&#xff08;图片来源&#xff1a;网络&#xff09; 空中客车公司&#xff08;Airbus&#xff09;和宝马集团&#xff08;BMW&#xff09;共同发起了一项名为“探索量子迁移率”的全球量子计算挑战赛&#xff0c;旨在解决航空和汽车领域仍未克服的紧迫难题。 此次挑战赛汇聚了…

map|二分查找|离线查询|LeetCode:2736最大和查询

本文涉及的基础知识点 二分查找算法合集 题目 给你两个长度为 n 、下标从 0 开始的整数数组 nums1 和 nums2 &#xff0c;另给你一个下标从 1 开始的二维数组 queries &#xff0c;其中 queries[i] [xi, yi] 。 对于第 i 个查询&#xff0c;在所有满足 nums1[j] > xi 且…

css3 clip-path剪切图片

大致看了一下&#xff0c;反正以后用到就慢慢调吧 剪切四个角 clip-path: polygon(14px 0, calc(100% - 14px) 0, 100% 14px, 100% calc(100% - 14px), calc(100% - 14px) 100%, 14px 100%, 0 calc(100% - 14px), 0 14px); 三角形 clip-path: polygon(50% 0,0 100%, 100% 100…

工业级以太网交换机的功能介绍

随着互联网技术的迅猛发展&#xff0c;工业以太网在工业通信领域中发挥着重要作用。在整个工业通信行业中&#xff0c;工业以太网交换机作为关键的通信设备&#xff0c;具有非常重要的功能。那么&#xff0c;什么是工业以太网交换机呢&#xff0c;它有哪些功能呢&#xff1f; …

山西电力市场日前价格预测【2023-12-15】

1.日前价格预测 预测说明&#xff1a; 如上图所示&#xff0c;预测明日&#xff08;2023-12-15&#xff09;山西电力市场全天平均日前电价为279.14元/MWh。其中&#xff0c;最高日前电价为380.47元/MWh&#xff0c;预计出现在00:45。最低日前电价为181.13元/MWh&#xff0c;预…

Linux----1、初始Linux

# 初识Linux # 一、计算机资源介绍 计算机资源分为2 部分&#xff1a;硬件资源、软件资源 硬件&#xff1a; 一般硬件是指计算机的物理组成&#xff0c;由真实&#xff08;看得见&#xff0c;摸得着&#xff09;的设备组成的 软件&#xff1a; 软件一般是指应用程序&#x…

运筹学经典问题(六):设施选址问题

问题描述 设施选址问题&#xff08;Facility Location Problem, FLP&#xff09;也成选址-分配问题&#xff0c;是企业面临的一类重要问题&#xff1a;在哪里建造设施&#xff1f;建造多少&#xff1f;以及将哪些客户分配给哪些设施去服务&#xff1f; 以物流业的航空站点选…

被带偏的中国云计算,重归正途

文 | 智能相对论 作者 | 叶远风 阿里云战略聚焦公共云&#xff0c;对整个云计算市场而言都是一场自我审视。 从市场背景、行业发展、中外对比等多个方面&#xff0c;业界舆论给出了大量详实的数据分析&#xff0c;已经对阿里云为什么要聚焦公共云有了结论&#xff0c;这里不…

【学习笔记】V8垃圾回收策略

V8 V8是一款主流的JavaScript执行引擎V8采用即时编译,速度比较快V8内存设限,64位操作系统中上限为1.5G,32位系统中不超过800M V8垃圾回收策略 采用分代回收的思想内存分为新生代\老生代针对不同对象采用不同算法 v8常用的GC算法: 分代回收、空间复制、标记清除、标记整理、…

docker-compose 单机容器编排

dockerfile---yml文件 docker-compose需要用到 yml文件 yml文件是什么&#xff1f; 是一种标记语言&#xff0c;以竖列的形式展示序列化的数据格式&#xff0c;可读性高&#xff0c;类似于json格式。语法简单。 YAML通过缩进来表示数据结构&#xff0c;连续的项目用 - 减号来表…

JS基础之变量对象

JS基础之变量对象 变量对象基础变量对象全局上下文函数上下文执行过程进入执行上下文代码执行思考题 变量对象 基础 当JavaScript代码执行一段可执行代码&#xff08;executable code&#xff09;时&#xff0c;会创建对应的执行上下文&#xff08;execution context&#xff…

什么是SEO优化

什么是SEO&#xff0c;百度其实就有答案&#xff0c;只是回答的很基础&#xff0c;说的都是基础概念&#xff0c;没有具体的体现在里面&#xff0c;SEO除了基础概念&#xff0c;还要有相应的构架&#xff0c;不然怎么弄都是一场空而已。 关于什么是SEO的文章导读&#xff1f; 1…

伦敦金收盘线应用有技巧

伦敦金的收盘线的绘制方式相当简单&#xff0c;其实也就是MT4中折线图的画法&#xff0c;我们可以在走势图以金价为纵坐标&#xff0c;而以时间为横坐标&#xff0c;然后将每一日的收盘价位值沿着横坐标一一的连接起来&#xff0c;就形成了伦敦金价的收盘线图。 利用线条简单的…

深入浅出讲解半桥栅极驱动器IC FAN7382MX

FAN7382MX是单片高端栅极驱动器IC,可以驱动最高在 600V 下运行的 MOSFET 和 IGBT。安森美的高电压工艺和共模干扰抑制技术提供了高压侧驱动器在高 dv/dt 干扰情况下的稳定运行。先进的电平转换电路可针对 VBS 15V 允许最高 VS -9.8 V&#xff08;典型值&#xff09;的高压侧门…

【Python】部署Rabbitmq消息队列实现生产和消费

原文作者&#xff1a;我辈李想 版权声明&#xff1a;文章原创&#xff0c;转载时请务必加上原文超链接、作者信息和本声明。 文章目录 前言一、基础的生产者消费者二、ACK消息确认机制三、类的写法1.新建MyRabbitMQ.py文件2.基础RabiitMQ3.发布订阅4.多次执行RabiitMQ_生产 四、…

Cannot find cache named ‘‘ for Builder Redis

当引入 Redissson 时&#xff0c;springCache 缓存机制失效 原因&#xff1a;springCache 默认使用本地缓存 Redisson 使用redis 缓存 最后都转成redis了。。。 总感觉哪不对 两者居然不共存

SU渲染受到电脑性能影响大吗?如何提高渲染速度

一般3d设计师们在进行设计工作前都需要提供一台高配电脑&#xff0c;那么你这知道su渲染对电脑要求高吗&#xff1f;电脑带不动su怎么解决&#xff1f;su对电脑什么配件要求高&#xff1f;今天这篇文章就详细为大家带来电脑硬件对su建模渲染的影响&#xff0c;以及su渲染慢怎么…

学习深度强化学习---第3部分----RL蒙特卡罗相关算法

文章目录 3.1节 蒙特卡罗法简介3.2节 蒙特卡罗策略评估3.3节 蒙特卡罗强化学习3.4节 异策略蒙特卡罗法 本部分视频所在地址&#xff1a;深度强化学习的理论与实践 3.1节 蒙特卡罗法简介 在其他学科中的蒙特卡罗法是一种抽样的方法。 如果状态转移概率是已知的&#xff0c;则是…

Axure的流程图/泳道图以及自定义元件库的使用

目录 1.ProcessOn的介绍 2.流程图以及泳道图的介绍 2.1流程图 2.2流程图的特点 2.3泳道图 2.4泳道图的特点 2.5流程图跟泳道图的优缺点 2.5.1优点&#xff1a; 2.5.2缺点&#xff1a; 2.6流程图的使用 2.7流程图的案列 2.8泳道图的使用 3.自定义元件库 4.门诊流程…