当前位置: 首页 > news >正文

MyBatis映射文件 <resultMap> 元素详解与示例


引言

<resultMap> 是 MyBatis 中最核心的映射配置元素,用于解决数据库字段与 Java 对象属性之间的复杂映射问题,尤其是字段名不一致、嵌套对象关联、集合映射等场景。ResultMap 的设计思想是,对简单的语句做到零配置,对于复杂一点的语句,只需要描述语句之间的关系就行了。以下是 <resultMap> 的详细解析和用法说明。


一、<resultMap> 基础结构

1. 核心属性
  • id:唯一标识符,用于其他操作引用此映射。
  • type:映射的目标 Java 对象类型(全限定类名或别名)。
  • autoMapping:是否启用自动映射(默认 false,建议部分场景开启)。
    在这里插入图片描述
2. 基础示例

场景:数据库字段为 user_id,Java 对象属性为 userId

<!-- 
用户结果映射(基础版本)
功能:将数据库查询结果映射到com.example.User对象
说明:1. id="BaseUserMap":标识这个结果映射的唯一名称。2. type="com.example.User":指定目标Java对象的完整类路径。3. <id property="userId" column="user_id">:定义主键属性userId与数据库列user_id的映射关系。4. <result property="userName" column="user_name">:定义普通属性userName与数据库列user_name的映射关系。5. <result property="age" column="age">:定义普通属性age与数据库列age的映射关系。
用法:在需要复杂映射的场景下,可复用此结果映射。-->
<resultMap id="BaseUserMap" type="com.example.User"><id property="userId" column="user_id" /><result property="userName" column="user_name" /><result property="age" column="age" />
</resultMap><!-- 
查询用户基本信息
功能:从users表中查询user_id、user_name和age列,并使用BaseUserMap结果映射转换为Java对象
说明:1. id="getUser":标识这个查询操作的唯一名称。2. resultMap="BaseUserMap":指定使用BaseUserMap结果映射来处理查询结果。3. SELECT user_id, user_name, age FROM users:从users表中查询指定列。
用法:在Mapper接口中定义对应的方法,例如:User getUser();返回一个包含用户基本信息的User对象。-->
<select id="getUser" resultMap="BaseUserMap">SELECT user_id, user_name, age FROM users
</select>

二、字段映射详解

1. <id><result> 的区别
  • <id>:标记主键字段,影响缓存和性能优化(必须配置)。
  • <result>:普通字段映射。
    在这里插入图片描述
2. 显式映射 vs 自动映射
  • 显式映射:手动配置所有字段(推荐复杂场景)。
  • 自动映射:开启 autoMapping="true" 后,未配置的字段按名称自动映射。
<!-- 
自动映射主键的用户结果映射
功能:使用MyBatis的自动映射功能,将数据库查询结果映射到User对象
特别说明:1. autoMapping="true":表示开启MyBatis的自动映射功能。- MyBatis会自动将查询结果中与User对象属性名匹配的列映射到对应的属性上。2. <id property="userId" column="user_id">:手动配置主键映射,确保主键列与User对象的userId属性正确对应。- 通常主键列需要显式定义,其他非主键列可以依赖自动映射完成。-->
<resultMap id="AutoUserMap" type="User" autoMapping="true"><id property="userId" column="user_id" /> <!-- 只需配置主键 -->
</resultMap><!-- 
查询用户信息(使用自动映射)
功能:从users表中查询所有用户信息,并通过AutoUserMap结果映射转换为User对象。
特别说明:- 该查询语句只需简单地从表中选择所有列(SELECT *),因为开启了自动映射,MyBatis会自动处理列名与User对象属性的映射。- 如果某些列名与User对象属性名不一致,可以手动在resultMap中配置对应的映射关系。-->
<select id="getUser" parameterType="String" resultMap="AutoUserMap">SELECT * FROM users
</select>

三、关联关系映射

1. 一对一关联 <association>

场景:用户(User)与身份证(IDCard)一对一关联。
Java 对象

public class User {private Integer userId;private String userName;private IDCard idCard; // 一对一对象
}

映射配置

<!-- 
用户与身份证信息的结果映射
功能:将用户信息和其关联的身份证信息映射到User对象
说明:1. id="UserWithIDCardMap":标识这个结果映射的唯一名称。2. type="User":指定目标Java对象类型为User。3. <id property="userId" column="user_id">:定义User对象的userId属性与数据库表的user_id列对应,作为主键。4. <result property="userName" column="user_name">:定义User对象的userName属性与数据库表的user_name列对应。5. <association property="idCard" javaType="IDCard">- property="idCard":User对象中的idCard属性,表示用户的身份证信息。- javaType="IDCard":指定关联对象的Java类型为IDCard。- <id property="cardId" column="card_id">:定义IDCard对象的cardId属性与数据库表的card_id列对应,作为主键。- <result property="cardNumber" column="card_number">:定义IDCard对象的cardNumber属性与数据库表的card_number列对应。- 通过这个关联映射,可以将用户的身份证信息嵌套到User对象中。-->
<resultMap id="UserWithIDCardMap" type="User"><id property="userId" column="user_id"/><result property="userName" column="user_name"/><!-- 嵌套对象映射 --><association property="idCard" javaType="IDCard"><id property="cardId" column="card_id"/><result property="cardNumber" column="card_number"/></association>
</resultMap><!-- 
查询用户及其身份证信息
功能:从users和id_card表中查询用户及身份证数据,并通过UserWithIDCardMap结果映射转换为Java对象
说明:1. id="getUserWithIDCard":标识这个查询操作的唯一名称。2. resultMap="UserWithIDCardMap":指定使用UserWithIDCardMap结果映射来处理查询结果。3. SELECT u.user_id, u.user_name, c.card_id, c.card_number FROM users u LEFT JOIN id_card c ON u.user_id = c.user_id:- 查询users表和id_card表的联合数据。- LEFT JOIN将users表和id_card表连接,连接条件为用户ID(u.user_id = c.user_id)。- 查询结果将包含用户的基本信息和其关联的身份证信息。
用法:在Mapper接口中定义对应的方法,例如:User getUserWithIDCard();返回一个包含用户及其身份证信息的User对象。-->
<select id="getUserWithIDCard" resultMap="UserWithIDCardMap">SELECT u.user_id, u.user_name, c.card_id, c.card_numberFROM users uLEFT JOIN id_card c ON u.user_id = c.user_id
</select>

2. 一对多关联 <collection>

场景:用户(User)与订单(Order)一对多关联。
Java 对象

public class User {private Integer userId;private String userName;private List<Order> orders; // 一对多集合
}

映射配置

<!-- 
用户与订单的结果映射
功能:将用户信息及其关联的订单信息映射到User对象
说明:1. id="UserWithOrdersMap":标识这个结果映射的唯一名称。2. type="User":指定目标Java对象类型为User。3. <id property="userId" column="user_id">:定义User对象的userId属性与数据库表的user_id列对应,作为主键。4. <result property="userName" column="user_name">:定义User对象的userName属性与数据库表的user_name列对应。5. <collection property="orders" ofType="Order">- property="orders":User对象中的orders属性,表示用户的订单集合。- ofType="Order":指定集合中元素的类型为Order。- <id property="orderId" column="order_id">:定义Order对象的orderId属性与数据库表的order_id列对应,作为主键。- <result property="orderNo" column="order_no">:定义Order对象的orderNo属性与数据库表的order_no列对应。- <result property="amount" column="amount">:定义Order对象的amount属性与数据库表的amount列对应。- 通过这个集合映射,可以将用户的订单信息作为嵌套集合封装到User对象中。-->
<resultMap id="UserWithOrdersMap" type="User"><id property="userId" column="user_id"/><result property="userName" column="user_name"/><!-- 集合映射 --><collection property="orders" ofType="Order"><id property="orderId" column="order_id"/><result property="orderNo" column="order_no"/><result property="amount" column="amount"/></collection>
</resultMap><!-- 
查询用户及其订单信息
功能:从users和orders表中查询用户及订单数据,并通过UserWithOrdersMap结果映射转换为Java对象
说明:1. id="getUserWithOrders":标识这个查询操作的唯一名称。2. resultMap="UserWithOrdersMap":指定使用UserWithOrdersMap结果映射来处理查询结果。3. SELECT u.user_id, u.user_name, o.order_id, o.order_no, o.amount FROM users u LEFT JOIN orders o ON u.user_id = o.user_id:- 查询users表和orders表的联合数据。- LEFT JOIN将users表和orders表连接,连接条件为用户ID(u.user_id = o.user_id)。- 查询结果将包含用户的基本信息和其关联的订单信息。
用法:在Mapper接口中定义对应的方法,例如:User getUserWithOrders();返回一个包含用户及其订单信息的User对象。-->
<select id="getUserWithOrders" resultMap="UserWithOrdersMap">SELECT u.user_id, u.user_name,o.order_id, o.order_no, o.amountFROM users uLEFT JOIN orders o ON u.user_id = o.user_id
</select>

四、高级用法

1. 继承映射 (extends)

复用已有的 resultMap,避免重复配置。

<!-- 
基础用户结果映射
功能:定义了一个基础的结果映射,包含用户的基本字段(user_id 和 user_name)
说明:1. id="BaseUserMap":标识这个结果映射的唯一名称。2. type="User":指定目标Java对象类型为User。3. <id property="userId" column="user_id">:定义User对象的userId属性与数据库表的user_id列对应,作为主键。4. <result property="userName" column="user_name">:定义User对象的userName属性与数据库表的user_name列对应。5. 这个基础映射可以被其他映射继承和扩展,避免重复定义公共字段。-->
<resultMap id="BaseUserMap" type="User"><id property="userId" column="user_id"/><result property="userName" column="user_name"/>
</resultMap><!-- 
扩展基础用户结果映射,添加新字段
功能:在基础用户映射的基础上,添加一个新的字段(email)
说明:1. id="ExtendedUserMap":标识这个结果映射的唯一名称。2. extends="BaseUserMap":表示继承BaseUserMap中的所有字段和配置。3. type="User":指定目标Java对象类型为User。4. <result property="email" column="email">:新增字段,定义User对象的email属性与数据库表的email列对应。5. 通过继承基础映射,可以避免重复定义公共字段,简化配置。-->
<resultMap id="ExtendedUserMap" extends="BaseUserMap" type="User"><result property="email" column="email"/>
</resultMap>

2. 构造函数映射 <constructor>

通过构造方法注入字段(适合不可变对象)。
Java 对象

public class User {private final Integer userId;private final String userName;public User(Integer userId, String userName) {this.userId = userId;this.userName = userName;}
}

映射配置

<!-- 
用户结果映射(基于构造函数)
功能:将数据库查询结果通过构造函数映射到User对象
说明:1. id="UserConstructorMap":标识这个结果映射的唯一名称。2. type="User":指定目标Java对象类型为User。3. <constructor>:表示将通过User类的构造函数来初始化对象。4. <arg column="user_id" javaType="int">:- 定义构造函数的第一个参数,对应数据库列user_id,Java类型为int。5. <arg column="user_name" javaType="String">:- 定义构造函数的第二个参数,对应数据库列user_name,Java类型为String。6. 这个结果映射要求User类有一个接受两个参数(int user_id, String user_name)的构造函数。
用法:在需要使用构造函数映射的场景下,通过这个resultMap将查询结果转换为User对象。-->
<resultMap id="UserConstructorMap" type="User"><constructor><arg column="user_id" javaType="int"/><arg column="user_name" javaType="String"/></constructor>
</resultMap>

3. 嵌套查询(分步查询)

解决关联查询的 N+1 性能问题,通过分步加载数据。

<!-- 
用户与订单的延迟加载映射 先查用户,再通过 user_id 查订单
功能:定义了一个结果映射,用于将用户信息和其关联的订单信息进行映射。在查询用户时,不会立即加载订单信息,而是通过延迟加载的方式在需要时再加载。
说明:1. id="UserWithLazyOrdersMap":标识这个结果映射的唯一名称。2. type="User":指定目标Java对象类型为User。3. <id property="userId" column="user_id">:定义User对象的userId属性与数据库表的user_id列对应,作为主键。4. <result property="userName" column="user_name">:定义User对象的userName属性与数据库表的user_name列对应。5. <collection property="orders" ofType="Order" select="com.example.OrderMapper.getOrdersByUserId" column="user_id">- property="orders":User对象中的orders属性,表示用户关联的订单集合。- ofType="Order":指定集合中元素的类型为Order。- select="com.example.OrderMapper.getOrdersByUserId":指定一个单独的SQL查询语句,用于根据用户ID查询订单信息。- column="user_id":将查询结果中的user_id列作为参数传递给子查询。-->
<resultMap id="UserWithLazyOrdersMap" type="User"><id property="userId" column="user_id"/><result property="userName" column="user_name"/><collection property="orders" ofType="Order"select="com.example.OrderMapper.getOrdersByUserId"column="user_id"/> <!-- 将 user_id 作为参数传递给子查询 -->
</resultMap><!-- 
查询用户信息(延迟加载订单)
功能:根据用户ID查询用户的基本信息,并通过延迟加载的方式获取其关联的订单信息。
说明:1. id="getUser":标识这个查询操作的唯一名称。2. resultMap="UserWithLazyOrdersMap":指定使用UserWithLazyOrdersMap结果映射来处理查询结果。3. SELECT user_id, user_name FROM users WHERE user_id = #{id}:- 查询users表中的user_id和user_name列。- WHERE user_id = #{id}:根据传入的用户ID进行查询。
用法:在Mapper接口中定义对应的方法,例如:User getUser(int id);返回一个包含用户基本信息的User对象,其orders属性在需要时才会加载。-->
<select id="getUser" resultMap="UserWithLazyOrdersMap">SELECT user_id, user_name FROM users WHERE user_id = #{id}
</select>

OrderMapper.xml

<!-- 
根据用户ID查询订单信息
功能:从orders表中查询指定用户的所有订单
参数:userId(用户ID)
返回:Order对象的列表,包含该用户的所有订单信息
说明:1. id="getOrdersByUserId":标识这个查询操作的唯一名称。2. resultType="Order":指定查询结果的类型为Order对象。3. SELECT * FROM orders WHERE user_id = #{userId}:- 查询orders表中所有列的数据。- WHERE user_id = #{userId}:条件是订单的user_id等于传入的userId参数。
用法:在Mapper接口中定义对应的方法,例如:List<Order> getOrdersByUserId(int userId);调用时传入用户ID,返回该用户的所有订单信息。-->
<select id="getOrdersByUserId" resultType="Order">SELECT * FROM orders WHERE user_id = #{userId}
</select>

在这里插入图片描述


五、常见问题与最佳实践

  1. 主键必须配置<id> 影响缓存机制,未配置可能导致性能下降。
  2. 避免过度嵌套:复杂关联建议使用分步查询(嵌套查询)减少单次 SQL 复杂度。
  3. 自动映射的取舍:简单场景可开启 autoMapping,复杂字段仍需显式配置。
  4. 性能优化:一对多关联使用懒加载(fetchType="lazy"),按需加载数据。

六、总结

拓展阅读:MyBatis映射文件常用元素详解与示例
官方文档:MyBatis | XML 映射文件
在这里插入图片描述

相关文章:

MyBatis映射文件 <resultMap> 元素详解与示例

引言 <resultMap> 是 MyBatis 中最核心的映射配置元素&#xff0c;用于解决数据库字段与 Java 对象属性之间的复杂映射问题&#xff0c;尤其是字段名不一致、嵌套对象关联、集合映射等场景。ResultMap 的设计思想是&#xff0c;对简单的语句做到零配置&#xff0c;对于复…...

leetcode刷题记录(一百零二)——45. 跳跃游戏 II

&#xff08;一&#xff09;问题描述 45. 跳跃游戏 II - 力扣&#xff08;LeetCode&#xff09;45. 跳跃游戏 II - 给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。每个元素 nums[i] 表示从索引 i 向后跳转的最大长度。换句话说&#xff0c;如果你在 nums[i] …...

2004-2016年各省煤炭基础储量数据

2004-2016年各省煤炭基础储量数据 1、时间&#xff1a;2004-2016年 2、指标&#xff1a;行政区划代码、地区、年份、煤炭基础储量(亿吨) 3、范围&#xff1a;31省 4、来源&#xff1a;国家统计局、统计年鉴 5、指标解释&#xff1a;煤炭基础储量是指在特定区域内&#xff…...

【含开题报告+文档+PPT+源码】基于spring boot的固定资产管理系统

开题报告 本研究论文提出了一种基于SpringBoot框架构建的全面且高效的固定资产管理系统&#xff0c;旨在优化企业内部的固定资产全生命周期管理流程。该系统集成了员工权限管理、业务流程处理及数据分析于一体&#xff0c;实现了员工便捷的登录注册功能&#xff0c;并通过安全…...

数据结构-链式二叉树

文章目录 一、链式二叉树1.1 链式二叉树的创建1.2 根、左子树、右子树1.3 二叉树的前中后序遍历1.3.1前(先)序遍历1.3.2中序遍历1.3.3后序遍历 1.4 二叉树的节点个数1.5 二叉树的叶子结点个数1.6 第K层节点个数1.7 二叉树的高度1.8 查找指定的值(val)1.9 二叉树的销毁 二、层序…...

C++中接口与继承的区别(自我学习用)

继承&#xff08;Inheritance&#xff09;和 接口&#xff08;Interface&#xff09;是面向对象编程&#xff08;OOP&#xff09;中的两种不同概念&#xff0c;虽然在 C 中没有像 Java 那样的 interface 关键字&#xff0c;但可以通过 纯虚函数 来实现接口的概念。让我们详细比…...

vue2拖拽式页面构建

在Vue 2中构建一个拖拽式页面&#xff0c;你可以使用第三方库如vuedraggable&#xff0c;它是基于Sortable.js的一个Vue组件&#xff0c;非常适合用于实现拖拽功能。 步骤 1: 安装vuedraggable 首先&#xff0c;你需要安装vuedraggable。在你的Vue项目中&#xff0c;运行以下命…...

ASUS/华硕天选3 FA507R FA707R 原厂Win11 21H2家庭版系统 工厂文件 带ASUS Recovery恢复

华硕工厂文件恢复系统 &#xff0c;安装结束后带隐藏分区&#xff0c;带一键恢复&#xff0c;以及机器所有的驱动和软件。 支持型号&#xff1a;FA507RC, FA507RE, FA507RM, FA507RW, FA707RC, FA707RE, FA707RM, FA707RW, FA507RH, FA707RH, FA507RR, FA707RR 系统版本&…...

部署onlyoffice后,php版的callback及小魔改(logo和关于)

作为这篇博文的补充CentOS9 安装Docker+Dpanel+onlyoffice(https、更改字体、字号、去除限制)的避坑笔记,现在继续… 本次主要内容有:php中callback的调用、自签证书调用callback遇到SSL certificate problem: unable to get local issuer certificate问题、修改onlyoffic…...

轻松打造专属音乐库:Alger Music本地部署与远程访问全流程解析

文章目录 前言1. 安装Docker2. 简单使用演示3. 安装cpolar内网穿透4. 配置公网地址5. 配置固定公网地址 前言 嗨&#xff0c;大家好&#xff01;今天我要给大家安利一款超级棒的第三方网抑云音乐播放器。这款神器不仅颜值超高、功能强大&#xff0c;还能让你彻底告别那些烦人的…...

redis集群的分片技术

Redis 集群模式通过 数据分片&#xff08;Sharding&#xff09; 技术将数据分布到多个节点上&#xff0c;从而实现横向扩展和高性能。以下是 Redis 集群分片技术的详细介绍&#xff1a; 1. 数据分片的基本原理 Redis 集群将整个数据集划分为 16384 个哈希槽&#xff08;Hash S…...

OA审批 / 流程管理 :流程设计/审批人设置/选择节点的审批人 | Java获取树形用户列表

文章目录 引言I 树形用户列表VO通用树状节点类型通用树状节点对象II 获取树形用户列表准备部门信息和用户信息III 其他相关表结构组织机构引言 流程设计/审批人设置/选择节点的审批人 树形显示用户列表(安装组织机构层级显示) 接口返回的树形用户的数据结构I 树形用户列表VO …...

【Pandas】pandas Series case_when

Pandas2.2 Series Computations descriptive stats 方法描述Series.align(other[, join, axis, level, …])用于将两个 Series 对齐&#xff0c;使其具有相同的索引Series.case_when(caselist)用于根据条件列表对 Series 中的元素进行条件判断并返回相应的值 pandas.Series.…...

.NET 9.0 的 Blazor Web App 项目,自定义日志 TLog V2 使用备忘

一、TLog V1 使用静态数据库上下文&#xff0c;优点是速度快&#xff0c;缺点是内存占用大&#xff0c;参见 .NET 9.0 的 Blazor Web App 项目、Bootstrap Blazor 组件库、自定义日志 TLog 使用备忘_navigationmanager.tobaserelativepath-CSDN博客 二、 TLog V2 改为 依赖注入…...

数据仓库与数据挖掘记录 二

1.数据仓库的产生 从 20 世纪 80 年代初起直到 90 年代初,联机事务处理一直是关系数据库应用的主流。然而,应用需求在不断地变化,当联机事务处理系统应用到一定阶段时,企业家们便发现单靠拥有联机事务处理系统已经不足以获得市场竞争的优势,他们需要对其自身业务的运作以及整个…...

SolidWorks速成教程P3-1【零件 | 第一节】——特征成型介绍拉伸凸台/基体与设计树

零件是由特征构成的&#xff0c;所以零件学习也叫做特征学习。 特征命令&#xff0c;我们可以认为是将二维草图变成三维实体的过程&#xff0c;学习完成后我们就能画出很多东西了&#xff0c;比如画一台手机的外形&#xff0c;学完后我们一起画一个手机支架&#xff0c;来熟练…...

vscode插件Remote - SSH使用教程

Remote - SSH 是一款非常实用的 Visual Studio Code (VSCode) 扩展插件,它允许开发者通过SSH连接到远程服务器,并像在本地一样进行代码编辑和调试。这意味着你可以直接在VS Code中打开位于远程机器上的文件夹,并利用本地安装的VS Code功能,如语法高亮、智能感知、Git集成等…...

sqli_labs_master Less-8 时间盲注,boolen盲注 获取数据库中的表、列

获取当前数据库名 import requestsdef inject_database(url):namemax_length20 # 假设数据库名称最大长度为20# ASCII范围&#xff1a;数字、字母、下划线&#xff08;_&#xff09;low{a: 97, z: 122, A: 65, Z: 90, 0: 48, 9: 57, _: 95}high{97: a, 122: z, 65: A, 90: Z,…...

Android Studio:RxJava事件流Observable

一、什么是“事件流”&#xff1f; 简单来说&#xff0c;事件流 就是数据从一个地方&#xff08;发布者&#xff09;传递到另一个地方&#xff08;订阅者&#xff09;的过程&#xff0c;像是一个“流水线”。发布者发布事件&#xff08;数据&#xff09;&#xff0c;订阅者则在…...

Influxdb学习 - TSM存储

InfluxDb为什么这么快 InfluxDB 之所以在时序数据场景下表现出色,主要得益于其专为时序数据优化的架构设计和多层次的性能优化策略 专为时序设计:TSM 引擎、列式存储、时间分区等特性直接针对时序数据痛点。写入优化:内存缓存 + 批量刷盘 + 高压缩率,最大化吞吐。查询加速…...

监控系统磁盘 I/O 性能的命令

iostat -x -k 1 是一个用于监控系统磁盘 I/O 性能的命令&#xff0c;下面详细解释该命令以及其输出各项的含义。 命令参数解释 iostat&#xff1a;这是一个用于报告中央处理器&#xff08;CPU&#xff09;统计信息和磁盘输入 / 输出统计信息的工具。 -x&#xff1a;显示扩展的…...

NumPy中生成和堆叠数组、生成切片的特殊对象:np.r_ np.c_ np.s_

在NumPy中有三个特殊的对象&#xff0c;非常好用&#xff1a; np.r_&#xff1a;按行连接两个数组&#xff0c;也就是将两个数组垂直堆叠。np.c_&#xff1a;按列连接两个数组&#xff0c;也就是将两个数组水平堆叠。np.s_&#xff1a;生成用于切片的slice对象。 下面详细介绍…...

js计算当(月/年)工作日(除去节假日)时间进度

js封装文件 // 获取当年的节假日12个月的数据 let holidaysArr [[1, 4, 5, 11, 12, 18, 19, 25, 26, 27, 28, 29, 30, 31], // 1月[1, 2, 3, 4, 5, 6, 9, 15, 16, 22, 23], // 2月[], // 3月[4, 5, 6, 12, 13, 19, 20, 26], // 4月[1, 2, 3, 4, 5, 10, 11, 17, 18, 24, 25, …...

zyNo.22

常见Web漏洞解析 命令执行漏洞 1.Bash与CMD常用命令 &#xff08;1&#xff09;Bash 读取文件&#xff1a;最常见的命令cat flag 在 Bash 中&#xff0c;cat 以及的tac、nl、more、head、less、tail、od、pr 均为文件读取相关命令&#xff0c;它们的区别如下&#xff1a; …...

服务器绑定 127.0.0.1 和 0.0.0.0 的区别

前言 IP 地址实际上并不是分配给计算机的&#xff0c;而是分配给网卡的&#xff0c;因此当计算机上存在多块网卡时&#xff0c;每一块网卡都会有自己的 IP 地址。 绑定 127.0.0.1 是绑定到 lookback 这个虚拟的本地回环接口&#xff0c;该接口只处理本机上的数据&#xff0c;…...

系统思考—团队学习

“一个人的成长是从问题中学习&#xff0c;而组织的成长是从结构中进化。” —— 彼得圣吉 看似松散的团队学习结构&#xff0c;回头一看&#xff0c;你早已成长了许多。今天和小伙伴们聊起2024年&#xff0c;才发现很多改变&#xff0c;都是在不经意间发生的。 从最初的探索…...

《Python百炼成仙》21-30章(不定时跟新)

第廿一章 列表开天可变序列初成 不周山的擎天玉柱裂开蛛网纹路&#xff0c;山体内部传出数据结构崩塌的轰鸣。叶军踏着《数据结构真解》残页凌空而立&#xff0c;手中薛香的本命玉尺泛起列表操作的幽光&#xff1a; 补天石序列 [五色石] * 9补天石序列[3] 息壤 # 引发链式变…...

element-ui时间组件同一个月内选择/30天内选择

element-ui时间组件同一个月内选择/30天内选择 同一个月 <el-date-picker v-model"time" type"datetimerange"range-separator"至" start-placeholder"开始时间"value-format"timestamp" :picker-options"pickerO…...

【大模型】阿里云百炼平台对接DeepSeek-R1大模型使用详解

目录 一、前言 二、DeepSeek简介 2.1 DeepSeek 是什么 2.2 DeepSeek R1特点 2.2.1 DeepSeek-R1创新点 2.3 DeepSeek R1应用场景 2.4 与其他大模型对比 三、阿里云百炼大平台介绍 3.1 阿里云百炼大平台是什么 3.2 阿里云百炼平台主要功能 3.2.1 应用场景 3.3 为什么选…...

微信小程序配置3 配置sass

1. 在config。json文件里面的setting配置“sass” 2. 改你需要的页面后缀名为scss。 3.查看页面即可看到样式。...

应用层优秀的共享民宿物联网框架该怎么选?

有一说一&#xff0c;应用层优秀的物联网框架通常能帮助提升用户体验、提高运营效率、节能减排等等优势&#xff0c;很多老板也很注重这个层面的设计和打磨&#xff0c;那么对于选择应用层优秀的共享民宿物联网框架时&#xff0c;大家可以从哪几个关键因素进行考量呢&#xff1…...

macOS 上部署 RAGFlow

在 macOS 上从源码部署 RAGFlow-0.14.1&#xff1a;详细指南 一、引言 RAGFlow 作为一款强大的工具&#xff0c;在人工智能领域应用广泛。本文将详细介绍如何在 macOS 系统上从源码部署 RAGFlow 0.14.1 版本&#xff0c;无论是开发人员进行项目实践&#xff0c;还是技术爱好者…...

postman登录cookie设置

1.设置环境变量&#xff0c; 定义变量存放共享的登录信息 如Cookie 2.登录接口编码test脚本获取cookie信息 let jsessionidCookie pm.cookies.get("JSESSIONID");if (jsessionidCookie) {let cookie "JSESSIONID" jsessionidCookie "; Admin-Tok…...

如何在Linux中设置定时任务(cron)

在Linux系统中&#xff0c;定时任务是自动执行任务的一种非常方便的方式&#xff0c;常常用于定期备份数据、更新系统或清理日志文件等操作。cron是Linux下最常用的定时任务管理工具&#xff0c;它允许用户根据设定的时间间隔自动执行脚本和命令。在本文中&#xff0c;我们将详…...

激光工控机在精密制造中的应用与优势

在精密制造中&#xff0c;激光工控机可以用于许多场景例如 激光切割与雕刻&#xff1a;用于金属、塑料、陶瓷等材料的精密切割和雕刻&#xff0c;适用于汽车、航空航天、电子等行业&#xff1b;可实现复杂图案和高精度加工&#xff0c;满足微米级精度要求。 激光焊接&#xf…...

conda的创建

1. 确认 conda 已安装 在使用 conda 创建环境之前&#xff0c;需要确保 conda 已经成功安装在你的系统中。你可以通过在命令行中输入以下命令来检查&#xff1a; conda --version如果已经安装&#xff0c;命令行会显示 conda 的版本号&#xff1b;若未安装&#xff0c;你可以…...

python视频爬虫

文章目录 爬虫的基本步骤一些工具模拟浏览器并监听文件视频爬取易错点一个代码示例参考 爬虫的基本步骤 1.抓包分析&#xff0c;利用浏览器的开发者工具 2.发送请求 3.获取数据 4.解析数据 5.保存数据 一些工具 requests, 用于发送请求&#xff0c;可以通过get&#xff0c;p…...

cv2.Sobel

1. Sobel 算子简介 Sobel 算子是一种 边缘检测算子&#xff0c;通过对图像做梯度计算&#xff0c;可以突出边缘。 Sobel X 方向卷积核&#xff1a; 用于计算 水平方向&#xff08;x 方向&#xff09; 的梯度。 2. 输入图像示例 假设我们有一个 55 的灰度图像&#xff0c;像素…...

Oracle入门精读03_Oracle11g安装目录及子目录的结构简介

在Windows2012 Server R2&#xff0c;个人把 Oracle Database 11g安装于硬盘D,如下&#xff1a; 在Oracle Database 11g中&#xff0c;Oracle的目录结构是由Oracle_Base及其子目录cfgtoollogs 、diag 、product、admin、flash_recovery_area和oradata等。这个与Oracle 10G不同的…...

Unity 卡死排查方法(游戏死循环、打包卡死)

适用场景 游戏运行一半卡住了 打包卡住了 工具 visual studio 方法 visual studio 启动工程&#xff0c;调试->附加到Unity&#xff0c;如果开了多个unity&#xff0c;可以用附加到进程找unity 打开线程窗口&#xff0c;调试->窗口->线程 点击暂停按钮&…...

开源、免费项目管理工具比较:2025最新整理30款

好用的开源、免费版项目管理系统有&#xff1a;1.Redmine&#xff1b;2. Taiga&#xff1b;3. OpenProject&#xff1b; 4.ProjectLibre&#xff1b; 5.GanttProject&#xff1b; 6.Tuleap&#xff1b; 7.Trac&#xff1b;8. Phabricator&#xff1b; 9.Notion&#xff1b; 10.…...

AlmaLinux使用Ansible自动部署k8s集群

以下是使用Ansible在AlmaLinux上自动化部署Kubernetes&#xff08;K8S&#xff09;集群的详细步骤&#xff1a; 1. 环境准备 1.1 节点规划 至少3台AlmaLinux 9服务器&#xff08;1个Master&#xff0c;2个Worker&#xff09;确保所有节点网络互通&#xff0c;SSH免密登录已配…...

Django创建超管用户

在 Django 中创建超级用户&#xff08;superuser&#xff09;可以通过命令行工具 createsuperuser 完成。以下是具体步骤&#xff1a; 1. 确保已进行数据库迁移 在创建超级用户前&#xff0c;确保已执行数据库迁移&#xff1a; python manage.py migrate 2. 创建超级用户 …...

机器翻译技术的演进与未来趋势:从规则到神经网络的革新

随着全球化的不断推进和多语言交流的日益频繁,机器翻译(Machine Translation, MT)技术的需求日益增长。机器翻译技术经历了从基于规则的方法到统计方法,再到如今的神经网络方法的发展历程。本文将探讨机器翻译技术的演进过程及其未来趋势,并结合Python代码示例,展示现代机…...

蓝桥杯备赛 Day13.1走出迷宫

链接&#xff1a;走出迷宫 题目描述 小明现在在玩一个游戏&#xff0c;游戏来到了教学关卡&#xff0c;迷宫是一个N*M的矩阵。 小明的起点在地图中用“S”来表示&#xff0c;终点用“E”来表示&#xff0c;障碍物用“#”来表示&#xff0c;空地用“.”来表示。 障碍物不能通…...

Word中Ctrl+V粘贴报错问题

Word中CtrlV粘贴时显示“文件未找到&#xff1a;MathPage.WLL”的问题 Word的功能栏中有MathType&#xff0c;但无法使用&#xff0c;显示灰色。 解决方法如下&#xff1a; 首先找到MathType安装目录下MathPage.wll文件以及MathType Commands 2016.dotm文件&#xff0c;分别复…...

C# Barrier 类使用详解

总目录 前言 Barrier 是 C# 中用于多线程分阶段协同工作的同步工具&#xff0c;位于 System.Threading 命名空间下。它允许多个线程在指定阶段&#xff08;Phase&#xff09;的屏障点&#xff08;Barrier Point&#xff09;同步&#xff0c;所有线程到达屏障点后&#xff0c;才…...

DeepSeek应用——与word的配套使用

目录 一、效果展示 二、配置方法 三、使用方法 四、注意事项 1、永久化使用 2、宏被禁用 3、office的生成失败 记录自己学习应用DeepSeek的过程...... 这个是与WPS配套使用的过程&#xff0c;office的与这个类似&#xff1a; 一、效果展示 二、配置方法 1、在最上方的…...

基于AIOHTTP、Websocket和Vue3一步步实现web部署平台,无延迟控制台输出,接近原生SSH连接

背景&#xff1a;笔者是一名Javaer&#xff0c;但是最近因为某些原因迷上了Python和它的Asyncio&#xff0c;至于什么原因&#xff1f;请往下看。在着迷”犯浑“的过程中&#xff0c;也接触到了一些高并发高性能的组件&#xff0c;通过简单的学习和了解&#xff0c;aiohttp这个…...

CentOS 7.8 安装MongoDB 7教程

文章目录 CentOS 7.8 安装MongoDB 7教程一、准备工作1. 系统更新2. 权限 二、添加MongoDB软件源1. 创建MongoDB的yum源文件2. 添加以下内容3. 保存并退出编辑器 三、安装MongoDB1. 更新yum缓存2. 安装MongoDB 四、启动MongoDB服务1. 启动MongoDB2. 设置MongoDB开机自启动 五、配…...