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

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

文章目录

  • 一、Mybatis中的自动映射是什么?
  • 二、Mybatis中的自定义映射是什么?
  • 三、为什么要使用自定义映射[resultMap]?
  • 四、自定义映射[resultMap]可以适用哪些场景?
    • 4.1 resultMap之级联映射
      • 4.1.1 级联映射之association映射[1:1]
      • 4.1.2 级联映射之collection映射[1:m]
    • 4.2 总结ResultMap中的相关标签及属性
    • 4.3 分步查询
      • 4.3.1 一对一的关联关系
      • 4.3.2 一对多的关联关系
      • 4.3.3 扩展
  • 五、Mybatis如何使用延迟加载【懒加载】?


在这里插入图片描述


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

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


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

👉定义

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

👉设计思想

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


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

💡原因

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

哪两类问题?

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

    不信?请看如下测试案例

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

    ①准备数据

    在这里插入图片描述

    在这里插入图片描述

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

    代码示例如下:

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

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

    代码示例如下:

    <select id="showempByempId" resultType="employee">SELECTe.`id`,e.`last_name`,e.`email`,e.`salary`,d.`dpt_id`,d.`dpt_name`FROM`tbl_employee` e, `tbl_department` dWHEREe.`dept_id`=d.`dpt_id`ANDe.`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();}}
    

    在这里插入图片描述

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

    🙇 原因

    书写的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">SELECTe.`id`,e.`last_name`,e.`email`,e.`salary`,d.`dpt_id`,d.`dpt_name`FROM`tbl_employee` e, `tbl_department` dWHEREe.`dept_id`=d.`dpt_id`ANDe.`id`=1;
</select>

②测试运行

在这里插入图片描述

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">SELECTe.`id`,e.`last_name`,e.`email`,e.`salary`,d.`dpt_id`,d.`dpt_name`FROM`tbl_employee` e, `tbl_department` dWHEREe.`dept_id`=d.`dpt_id`ANDe.`id`=1;
</select>

②测试运行

在这里插入图片描述

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

👉特点

解决一对多的关联关系

👉用法案例

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

代码示例如下:

准备数据

在这里插入图片描述

①在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">SELECTe.`id`,e.`last_name`,e.`email`,e.`salary`,d.`dpt_id`,d.`dpt_name`FROM`tbl_employee` e, `tbl_department` dWHEREe.`dept_id`=d.`dpt_id`ANDd.`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();}}

在这里插入图片描述

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">selectdpt_Id,dpt_namefromtbl_departmentwheredpt_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();}}

在这里插入图片描述

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();}}

在这里插入图片描述

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();
}

在这里插入图片描述

🚀②局部设置

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

运行测试如下

在这里插入图片描述


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

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

相关文章

工作纪实34-emoji表情包存储异常,修改db的字段类型

线上问题&#xff0c;发现emojo表情写入数据库出现异常 修改mysql字段的字符集 ALTER TABLE customer_cycle_info MODIFY COLUMN customer_sales_remark varchar(500) CHARACTER SET

【node】使用express+gitee搭建图床,并解决防盗链问题

首先创建一个gitee的项目&#xff0c;详细步骤我就不一一说明 注解&#xff1a;大家记得将这个项目开源&#xff0c;还有记得获取自己的私钥&#xff0c;私钥操作如下&#xff1a; node依赖下载&#xff1a; "axios": "cors": "express"…

IOS自动化测试环境搭建教程

目录 一、前言 二、环境依赖 1、环境依赖项 2、环境需求与支持 三、环境配置 1、xcode安装 2、Git安装 3、Homebrew安装&#xff08;用brew来安装依赖&#xff09; 4、npm和nodejs安装 5、libimobiledevice安装 6、idevicesinstaller安装 7、ios-deploy安装 8、Ca…

安卓的播放器对比与选型(vlc,EXOplayer,Ijkplayer,GSYVideoPlayer)详细过程

安卓的播放器对比与选型&#xff08;vlc&#xff0c;EXOplayer&#xff0c;Ijkplayer&#xff0c;GSYVideoPlayer&#xff09;&#x1f4fa;详细过程 前言一、vlc二、EXOplayer三、Ijkplayer四、GSYVideoPlayer&#x1f525;&#x1f525;&#x1f525;五、其他的开源播放器jia…

GPT-AI 使用的技术概览

ChatGPT 使用的技术概览 智心AI-3.5/4模型&#xff0c;联网对话&#xff0c;MJ快速绘画 从去年 OpenAI 发布 ChatGPT 以来&#xff0c;AI 的能力再次惊艳了世人。在这样的一个时间节点&#xff0c;重新去学习相关技术显得很有必要。 ChatGPT 的内容很多&#xff0c;我计划采用…

Spring Boot 2.7.8以后mysql-connector-java与mysql-connector-j

错误信息 如果升级到Spring Boot 2.7.8&#xff0c;可以看到因为找不到mysql-connector-java依赖而出现错误。 配置&#xff1a; <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId>&l…

win11安装appium

node安装 node下载网址: Download | Node.js 安装后对node安装包路径进行配置 npm config set prefix “E:\nodejs\node_global” //设置全局包目录 npm config set cache “E:\nodejs\node_cache” //设置缓存目录npm config list //查看npm配置npm install -g appium //安…

Java面试笔记

JAVA基础知识 语法结构 1.类 2.属性 3.方法 4.静态代码块 构造器 构造函数&#xff0c;构造类的对象&#xff0c;默认隐式&#xff0c;创建对象&#xff0c;先执行父类构造函数&#xff0c;再执行子类构造函数 父类的super必须在第一行 代码块 优先级最高&#xff0c;只…

Modbus TCP/IP之异常响应

文章目录 一、异常响应二、异常码分析2.1 异常码0x012.2 异常码0x022.3 异常码0x032.4 异常码0x04、0x05等 一、异常响应 对于查询报文&#xff0c;存在以下四种处理反馈&#xff1a; 正常接收&#xff0c;正常处理&#xff0c;返回正常响应报文&#xff1b;因为通信错误等原因…

全志F1C200S嵌入式驱动开发(基于usb otg的spi-nor镜像烧入)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】 前面既然已经搞定了spi-nor驱动,那么下一步考虑的就是怎么从spi-nor flash上面加载uboot、kernel和rootfs。目前spi-nor就是一块白片,上面肯定什么都没有,那么这个时候,我们要做…

UE5、CesiumForUnreal实现选中区域地形压平效果

文章目录 1.实现目标2.实现过程2.1 Demo说明2.2 实现过程3.参考资料声明:本篇文章是为某位读者朋友定制开发的功能需求,所以放在了特定的专栏里,其他的朋友可以忽略这篇文章哈! 1.实现目标 基于CesiumForUnreal插件的CesiumPolygonRasterOverlay组件实现选中区域地形压平的…

构建自己的ChatGPT:从零开始构建个性化语言模型

&#x1f337;&#x1f341; 博主 libin9iOak带您 Go to New World.✨&#x1f341; &#x1f984; 个人主页——libin9iOak的博客&#x1f390; &#x1f433; 《面试题大全》 文章图文并茂&#x1f995;生动形象&#x1f996;简单易学&#xff01;欢迎大家来踩踩~&#x1f33…

【力扣每日一题】2023.7.27 删除每行中的最大值

目录 题目&#xff1a; 示例&#xff1a; 分析&#xff1a; 代码运行结果&#xff1a; 题目&#xff1a; 示例&#xff1a; 分析&#xff1a; 给我们一个矩阵&#xff0c;每次都把每行中的最大元素拿出来删掉&#xff0c;再把每次删除的元素里最大的元素拿出来加到结果里&…

Jetbrains 2023.2教程

IDEA 2023.2 激活演示 Pycharm 2023.2 激活演示 WebStorm 2023.2 激活演示 Clion 2023.2 激活演示 DataGrip 2023.2 PhpStorm 2023.1.4 激活演示&#xff08;2023.2尚未发布&#xff09; RubyMine 2023.2 激活演示 获取方式 仔细看每一个工具演示的图片 本文由 mdnice …

火车头神码ai伪原创【php源码】

大家好&#xff0c;小编来为大家解答以下问题&#xff0c;python中常用的类&#xff0c;python 类的用法&#xff0c;现在让我们一起来看看吧&#xff01; 火车头采集ai伪原创插件截图&#xff1a;

Python - OpenCV实现摄像头人脸识别(亲测版)

要使用Python 3和OpenCV进行摄像头人脸识别&#xff0c;您可以按照以下步骤进行操作&#xff1a; 1.安装OpenCV库 在命令行中输入以下命令&#xff1a; pip install opencv-python2.准备人脸检测器 使用OpenCV的人脸检测器可以检测出图像中的人脸。在Python中&#xff0c;您…

【Terraform学习】TerraformCloud入门介绍(快速入门)

TerraformCloud入门介绍 什么是 TerraformCloud&#xff1f; Terraform Cloud是Hashicorp Terraform的SaaS版本。 免费版功能 免费版功能包括版本控制集成、远程计划和实施远程计划和实施、通知及webhook、全http API驱动、状态管理、模拟计划、私有化模块注册器以及全HTTP界…

LabVIEW开发谐振器陀螺仪仿真系统

LabVIEW开发谐振器陀螺仪仿真系统 陀螺仪是INS系统中最重要的传感器。它们的性能&#xff08;如精度和偏置稳定性&#xff09;决定了INS系统的水平。陀螺仪按原理分为三类&#xff1a;角动量守恒、萨格纳克效应和科里奥利效应。旋转坐标系中的移动物体受到的力与旋转坐标系的角…

7-22练习

题目1 链接5071 不难发现通过A的范围可以缩小B的范围进而减少循环次数 通过B可以消除A的循环 这个是一个很巧妙的地方。这个题还有一个比较容易引起歧义的地方就是i:n每一次循环都要符合条件 这样我们不难构造出一个函数 f(B+x) = 1000*A+x 试验1 运行超时-- 需要减少复杂度…

Hive视图

hive的视图 简介 hive的视图简单理解为逻辑上的表hive只支持逻辑视图&#xff0c;不支持物化视图视图存在的意义 对数据进行局部暴露&#xff08;涉及隐私的数据不暴露&#xff09;简化复杂查询 创建视图&#xff1a; create view if not exists v_1 as select uid,movie f…