MySQL JOIN详解:INNER JOIN与LEFT JOIN的选择与应用
在数据库查询中,JOIN操作是最常用也最重要的操作之一。不同的JOIN类型会导致完全不同的查询结果,正确选择JOIN类型是编写高效、准确SQL查询的关键。本文将深入探讨INNER JOIN和LEFT JOIN的区别、应用场景以及常见问题。
一、JOIN基础概念
1. 什么是JOIN
JOIN操作用于将两个或多个表中的数据基于相关字段进行组合。通过JOIN,我们可以实现:
-
关联查询分散在不同表中的数据
-
减少数据冗余
-
建立复杂的数据关系模型
2. JOIN的主要类型
MySQL支持多种JOIN类型,最常见的两种是:
-
INNER JOIN(内连接)
-
LEFT JOIN(左连接,LEFT OUTER JOIN的简写)
其他类型还包括RIGHT JOIN、FULL OUTER JOIN等,但在MySQL中较少使用。
二、INNER JOIN详解
1. 基本语法
SELECT 列名
FROM 表1
INNER JOIN 表2 ON 表1.列 = 表2.列;
2. 工作原理
INNER JOIN只返回两个表中匹配条件成立的行。如果某行在左表存在但在右表没有匹配,或者反之,这些行都不会出现在结果中。
3. 特点
-
严格匹配:只返回两表都有的数据
-
结果集较小:相比LEFT JOIN通常返回更少的行
-
性能较好:在大多数情况下比OUTER JOIN效率高
-
不会产生NULL值:因为只返回匹配的行
4. 适用场景
-
需要严格关联数据的查询
-- 查询有订单的客户信息 SELECT customers.name, orders.order_date FROM customers INNER JOIN orders ON customers.id = orders.customer_id;
-
多表关联查询且必须所有表都存在相关记录
-- 查询已完成支付的订单详情 SELECT orders.id, order_items.product_name, payments.amount FROM orders INNER JOIN order_items ON orders.id = order_items.order_id INNER JOIN payments ON orders.id = payments.order_id WHERE payments.status = 'completed';
-
数据清洗,只保留有关联的数据
5. 示例图解
表A 表B
id name id a_id value
1 Alice 1 1 100
2 Bob 2 1 200
3 Carol 3 3 300INNER JOIN 结果:
A.id A.name B.value
1 Alice 100
1 Alice 200
3 Carol 300
三、LEFT JOIN详解
1. 基本语法
SELECT 列名
FROM 表1
LEFT JOIN 表2 ON 表1.列 = 表2.列;
2. 工作原理
LEFT JOIN返回左表的所有行,即使右表中没有匹配的行。如果右表没有匹配,结果中右表的列将显示为NULL。
3. 特点
-
保留左表全部数据:无论右表是否有匹配
-
结果集较大:通常比INNER JOIN返回更多行
-
可能产生NULL值:右表无匹配时显示NULL
-
性能考虑:通常比INNER JOIN消耗更多资源
4. 适用场景
-
需要保留主表全部记录的查询
-- 查询所有客户及其订单(包括没有订单的客户) SELECT customers.name, orders.order_date FROM customers LEFT JOIN orders ON customers.id = orders.customer_id;
-
统计存在/不存在关系
-- 找出从未下过单的客户 SELECT customers.name FROM customers LEFT JOIN orders ON customers.id = orders.customer_id WHERE orders.id IS NULL;
-
分级查询完整结构
-- 查询部门及员工(包括没有员工的部门) SELECT departments.name, employees.employee_name FROM departments LEFT JOIN employees ON departments.id = employees.dept_id;
5. 示例图解
表A 表B
id name id a_id value
1 Alice 1 1 100
2 Bob 2 1 200
3 Carol 3 3 300
4 DaveLEFT JOIN 结果:
A.id A.name B.value
1 Alice 100
1 Alice 200
2 Bob NULL
3 Carol 300
4 Dave NULL
四、INNER JOIN vs LEFT JOIN对比
特性 | INNER JOIN | LEFT JOIN |
---|---|---|
返回行 | 只返回匹配的行 | 返回左表所有行+匹配的右表行 |
结果集大小 | 通常较小 | 通常较大 |
NULL值 | 不会产生 | 右表无匹配时产生NULL |
性能 | 通常更好 | 通常稍差 |
使用频率 | 非常高 | 高 |
适用场景 | 需要严格匹配的查询 | 需要保留左表完整数据的查询 |
五、常见问题与解决方案
1. INNER JOIN容易报错吗?
问题本质:INNER JOIN本身不会报错,但在以下情况可能出现问题:
-
关联字段NULL值:
-- 如果customer_id有NULL值,这条记录不会出现在结果中 SELECT * FROM orders INNER JOIN customers ON orders.customer_id = customers.id;
-
关联字段数据类型不匹配:
-- 如果id是INT而customer_id是VARCHAR,可能导致性能问题或不匹配 SELECT * FROM orders INNER JOIN customers ON orders.customer_id = customers.id;
-
多表关联时的严格性:
-- 如果任意一个JOIN条件不满足,整行都会被过滤 SELECT * FROM table1 INNER JOIN table2 ON table1.id = table2.t1_id INNER JOIN table3 ON table2.id = table3.t2_id;
解决方案:
-
确保关联字段有适当的索引
-
处理可能的NULL值情况
-
验证关联字段的数据类型一致性
-
使用LEFT JOIN+WHERE替代部分INNER JOIN场景
2. 什么时候该用INNER JOIN,什么时候该用LEFT JOIN?
决策树:
-
是否需要保留左表的所有记录?
-
是 → 使用LEFT JOIN
-
否 → 进入问题2
-
-
是否只关心两表都有数据的记录?
-
是 → 使用INNER JOIN
-
否 → 可能需要其他JOIN类型
-
经验法则:
-
报表类查询通常使用LEFT JOIN保证数据完整性
-
事务处理类查询通常使用INNER JOIN确保数据一致性
-
统计"有/无"类查询使用LEFT JOIN + WHERE IS (NOT) NULL
3. 性能优化建议
-
为JOIN字段建立索引:
ALTER TABLE orders ADD INDEX (customer_id);
-
小表驱动大表:
-- 让数据量小的表作为驱动表(放在FROM后) SELECT * FROM small_table INNER JOIN large_table ON small_table.id = large_table.s_id;
-
避免不必要的列:
-- 只选择需要的列,不要SELECT * SELECT customers.name, orders.order_date FROM ...
-
考虑使用STRAIGHT_JOIN(MySQL特定):
-- 强制按FROM顺序执行JOIN SELECT STRAIGHT_JOIN * FROM table1 INNER JOIN table2 ON ...
六、实际案例解析
案例1:电商平台查询
需求:查询所有商品及其最近一次订单信息(包括从未被订购的商品)
SELECT p.product_id,p.product_name,o.order_date,o.quantity
FROM products p
LEFT JOIN (SELECT product_id,order_date,quantity,RANK() OVER (PARTITION BY product_id ORDER BY order_date DESC) as rnkFROM order_items
) o ON p.product_id = o.product_id AND o.rnk = 1;
案例2:员工管理系统
需求:统计各部门员工数量(包括没有员工的部门)
SELECT d.dept_name,COUNT(e.emp_id) as employee_count
FROM departments d
LEFT JOIN employees e ON d.dept_id = e.dept_id
GROUP BY d.dept_id, d.dept_name;
案例3:数据质量检查
需求:找出有客户记录但没有对应用户账号的数据
SELECT c.customer_id,c.customer_name
FROM customers c
LEFT JOIN user_accounts u ON c.email = u.username
WHERE u.user_id IS NULL;
七、高级话题
1. JOIN与WHERE条件的执行顺序
-- 这两种写法在INNER JOIN中等价
SELECT * FROM A INNER JOIN B ON A.id = B.a_id WHERE B.value > 100;
SELECT * FROM A INNER JOIN B ON A.id = B.a_id AND B.value > 100;-- 但在LEFT JOIN中不等价
SELECT * FROM A LEFT JOIN B ON A.id = B.a_id WHERE B.value > 100; -- 会过滤掉NULL
SELECT * FROM A LEFT JOIN B ON A.id = B.a_id AND B.value > 100; -- 保留NULL
2. 多表JOIN的最佳实践
-
明确每个JOIN的目的:是过滤数据(INNER)还是保留数据(LEFT)
-
注意JOIN顺序:通常从主表开始,逐步关联
-
合理使用别名:提高可读性
-
考虑使用CTE:复杂JOIN可以先用WITH分解
WITH order_totals AS (SELECT order_id, SUM(amount) as totalFROM order_itemsGROUP BY order_id
)
SELECT c.customer_name,o.order_date,ot.total
FROM customers c
INNER JOIN orders o ON c.customer_id = o.customer_id
LEFT JOIN order_totals ot ON o.order_id = ot.order_id;
八、总结与最佳实践
-
优先考虑INNER JOIN:除非明确需要保留不匹配的行
-
LEFT JOIN用于保留性查询:如报表、统计分析
-
始终验证JOIN条件:确保关联字段正确且高效
-
注意NULL处理:特别是LEFT JOIN后的WHERE条件
-
性能监控:EXPLAIN是你的好朋友
-
保持一致性:团队应建立统一的JOIN使用规范
正确使用JOIN操作可以大幅提高SQL查询的效率和准确性。理解INNER JOIN和LEFT JOIN的本质区别,根据实际业务需求选择合适的JOIN类型,是每个数据库开发人员必备的技能。
respect!
相关文章:
MySQL JOIN详解:INNER JOIN与LEFT JOIN的选择与应用
在数据库查询中,JOIN操作是最常用也最重要的操作之一。不同的JOIN类型会导致完全不同的查询结果,正确选择JOIN类型是编写高效、准确SQL查询的关键。本文将深入探讨INNER JOIN和LEFT JOIN的区别、应用场景以及常见问题。 一、JOIN基础概念 1. 什么是JOI…...
Flink 反压下的 TCP 流控制
1. 什么是 Flink 反压和 TCP 流控制? 反压(Backpressure)是什么? 反压是分布式流处理系统中一种自我调节机制。当下游处理数据的速度跟不上上游发送数据的速度时,反压会让上游放慢发送速度,以避免系统过载…...
山东大学软件学院项目实训开发日志(7)之测试前后端本地部署
基于队长搭建的springbootvue框架,在本地进行测试搭建。 在运行后端过程中,出现下图错误: 查找后发现这个问题出现在 Maven 项目的 pom.xml 文件中,显示找不到一些依赖项。所以在此进行最简单的重新加载项目得以解决,…...
YOLOv11训练中精准率召回率与mAP@0.5的动态变化分析
目标检测模型的训练过程涉及多个关键性能指标和损失函数的变化,这些数据能够直观反映模型的收敛速度、最终精度以及改进效果。本文旨在通过绘制YOLOv11模型在训练过程中的精准率(Precision)、召回率(Recall)、mAP0.5 、…...
Windows下ElasticSearch8.x的安装步骤
下载ElasticSearch:https://www.elastic.co/downloads/elasticsearch (我下载的是目前最新版8.17.4)解压ElasticSearch 进入到ElasticSearch的bin目录下双击elasticsearch.bat 弹出控制台并开始执行,在这一步会输出初始账号和密码…...
Leetcode hot100 (day 8,9)
爬楼梯 做法一:小斐波那契数列,只要注意记忆化递归即可 class Solution { public:int dp[50];int climbStairs(int n) {if(dp[n])return dp[n];if(n2){return dp[2]2;}if(n1){return dp[1]1;}//if(dp[n])return dp[n];return dp[n]climbStairs(n-1)clim…...
LinuxSocket套接字编程
1.介绍函数使用 1.创建套接字 int socket(int domain, int type, int protocol); domain:指定协议族,如AF_INET(IPv4)或AF_INET6(IPv6)。 type:指定套接字类型,如SOCK_DGRAM&#…...
青少年编程考试 CCF GESP Python五级认证真题 2025年3月
Python 五级 2025 年 03 月 题号 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 答案 A A A B D B A D A D C A A D B 1 单选题(每题 2 分,共 30 分) 第 1 题 链表不具备的特点是( )。 A. 可随机访问任何一个元素 B. 插入、删除操作不需要移动元素 C…...
Java-对比两组对象找出发生变化的字段工具-支持枚举映射-支持时间-支持显示对应字段中文描述-嵌套list等场景
实体字段比较器(对比两组对象找出发生变化的字段工具类开发) 支持枚举映射 支持时间 支持显示对应字段中文描述 支持嵌套list等场景 下载地址: Java-对比两组对象找出发生变化的字段工具-支持枚举映射-支持时间-支持显示对应字段中文描述-嵌…...
电影舆情分析可视化平台管理端实现
电影舆情分析可视化平台管理端实现 系统概述 本系统的用户主要有三类,游客、普通用户以及电影从业人员。 面向游客和普通用户的是电影网站,系统提供一个便捷的平台,供普通用户搜索和了解电影的基本信息,支持电影预告片播放&…...
【Linux】进程信号(下)
在上一篇中,我们详细探讨了信号的预备知识和产生方式(如硬件异常、终端输入、kill命令、系统调用等)及其背后的操作系统行为。信号作为进程间异步通信的核心机制,其生命周期远不止“产生”这一环节——信号的保存与处理才是实现可…...
华为数字芯片机考2025合集2已校正
单选 1. 题目内容 关于亚稳态的描述错误的是( )。 1. 解题步骤 1.1 理解亚稳态(Metastability)的核心特性 亚稳态是指触发器无法在指定时间内稳定输出有效逻辑电平(0或1)的状态,其关键特点…...
【大模型微调】如何解决llamaFactory微调效果与vllm部署效果不一致如何解决
以下个人没整理太全 一、生成式语言模型的对话模板介绍 使用Qwen/Qwen1.5-0.5B-Chat训练 对话模板不一样。回答的内容就会不一样。 我们可以看到例如qwen模型的tokenizer_config.json文件,就可以看到对话模板,一般同系列的模型,模板基本都…...
基于视觉语言模型的机器人实时探索系统!ClipRover:移动机器人零样本视觉语言探索和目标发现
作者:Yuxuan Zhang 1 ^{1} 1, Adnan Abdullah 2 ^{2} 2, Sanjeev J. Koppal 3 ^{3} 3, and Md Jahidul Islam 4 ^{4} 4单位: 2 , 4 ^{2,4} 2,4佛罗里达大学电气与计算机工程系RoboPI实验室, 1 , 3 ^{1,3} 1,3佛罗里达大学电气与计算机工程系F…...
Java常用工具算法-6--秘钥托管云服务AWS KMS
前言: 之前我们介绍了一些常用的加密算法(如:对称加密AES,非对称加密RSA,ECC等),不论是哪一种都需要涉及到秘钥的管理。通常的做法都是把秘钥放到配置文件中进行配置,但是对于一些高…...
Shell脚本的学习
编写脚本文件 定义以开头:#!/bin/bash #!用来声明脚本由什么shell解释,否则使用默认shel 第一步:编写脚本文件 #!/bin/bash #注释 echo "这是输出" 第二步:加上执行权限:chmod x 脚本文件名.sh 第三步&…...
Java——pdf增加水印
文章目录 前言方式一 itextpdf项目依赖引入编写PDF添加水印工具类测试效果展示 方式二 pdfbox依赖引入编写实现类效果展示 扩展1、将inputstream流信息添加水印并导出zip2、部署出现找不到指定字体文件 资料参考 前言 近期为了知识库文件导出,文件数据安全处理&…...
Redis过期key处理、内存淘汰策略与缓存一致性策略实践方案
在现代的高性能应用开发中,Redis作为一款极为热门的内存数据库,其快速的读写性能和丰富的数据结构使其在缓存、消息队列等诸多领域得到了广泛应用。然而,在实际使用过程中,处理好Redis过期key、选择合适的内存淘汰策略以及确保缓存…...
深入 C++ 线程库:从创建到同步的探索之旅
C在<thread>中定义了C线程库. 创建多线程 #include <iostream> #include <thread> using namespace std; void show(int id, int count) { //线程函数for (int i 0; i < count; i) {cout << "id:" << id << ",值:&qu…...
LangChain使用大语言模型构建强大的应用程序
LangChain简介 LangChain是一个强大的框架,旨在帮助开发人员使用语言模型构建端到端的应用程序。它提供了一套工具、组件和接口,可简化创建由大型语言模型 (LLM) 和聊天模型提供支持的应用程序的过程。LangChain 可以轻松管理与语言模型的交互ÿ…...
程序化广告行业(72/89):Tag Manager系统代码操作与行业发展剖析
程序化广告行业(72/89):Tag Manager系统代码操作与行业发展剖析 大家好!在技术领域不断探索的过程中,我深刻体会到知识共享的重要性。写这篇博客,就是希望能和大家一起深入了解程序化广告行业,…...
数据结构实验3.3:求解迷宫路径问题
文章目录 一,问题描述二,基本要求三,算法分析(一)整体思路(二)详细步骤1. 输入迷宫大小并生成迷宫2. 定义走步规则3. 深度优先搜索(DFS)4. 输出结果 (三&…...
基于SpringBoot的线上历史馆藏系统【附源码】
基于SpringBoot的线上历史馆藏系统(源码L文说明文档) 4 系统设计 系统在设计的过程中,必然要遵循一定的原则才可以,胡乱设计是不可取的。首先用户在使用过程中,能够直观感受到功能操作的便利性,符合…...
Mybatis的springboot项目使用
删除数据 & 占位符 一般常用占位符进行数据库操作,也就是预编译sql。 在UserMapper中定义删除接口 /** 根据id删除用户*/ Delete("delete from user where id #{id}") void deleteById(Integer id);若想要获取返回值,声明为Integer (s…...
网站集群批量管理-Ansible剧本与变量
复盘内容:链接指北 查看ansible命令文档 ansible-doc -s systemd一、剧本 何为剧本: playbook 文件,用于长久保存并且实现批量管理,维护,部署的文件. 类似于脚本存放命令和变量 剧本yaml格式,yaml格式的文件:空格,冒号. 剧本未来我们批量管理,运维必会的内容. …...
HOW - React Developer Tools 调试器
目录 React Developer Tools使用Components 功能特性1. 查看和编辑 props/state/hooks2. 查找组件3. 检查组件树4. 打印组件信息5. 检查子组件 Profiler 功能特性Commit ChartFlame Chart 火焰图Ranked Chart 排名图 why-did-you-render 参考文档: React调试利器&a…...
Spring Cloud Alibaba微服务治理实战:Nacos+Sentinel深度解析
一、引言 在微服务架构中,服务发现、配置管理、流量控制是保障系统稳定性的核心问题。Spring Cloud Netflix 生态曾主导微服务解决方案,但其部分组件(如 Eureka、Hystrix)已进入维护模式。 Spring Cloud Alibaba 凭借 高性能、轻…...
《AI换脸时代的攻防暗战:从技术滥用走向可信未来》
技术迭代图谱 过去五年里,Deepfake技术经历了飞速迭代,从最初的萌芽到如今的广泛应用和对抗措施形成。2017年前后,利用深度学习进行人脸换装的技术首次在社区中出现。一位Reddit网友昵称“deepfakes”,将名人面孔替换到色情影片上…...
25/4/9 算法笔记 DBGAN+强化学习+迁移学习实现青光眼图像去模糊1
整体实验介绍 实验主要是结合DBGAN对抗网络强化学习增强迁移学习增强实现青光眼图像去模糊。今天则是先完成了DBGAN板块模型的训练。 实验背景介绍 青光眼的主要特征有: 视盘形态与杯盘比CDR:青光眼患者主要表现为视杯扩大,盘沿变窄。 视…...
【Claude AI大语言模型连接Blender生成资产】Windows安装Blender MCP教程
前言 最近在学习资产制作,了解到了个好玩的东西,利用AI一步一步搭建资产: 上面这副图就是利用Claude AI调用Blender的Python接口一步一步实现的,挺丑但好玩。 安装教程 进入Github: Blender-MCP 网站,下载该项目&a…...
JSP运行环境安装及常用HTML标记使用
制作一个静态网站的基本页面index.html 实验代码:<form> <label for"username">用户名:</label> <input type"text" id"username" name"username"><br> <label for"password&…...
Git 的进阶功能和技巧
1、分支的概念和使用 1.1、什么是分支? 分支(Branch)是在版本控制中非常重要的概念。几乎所有版本控制系统都支持某种形式的分支。在 Git 中,分支是 Git 强大功能之一,它允许我们从主开发线分离出来,在不…...
WSL1升级到WSL2注意事项
今天要在WSL上安装docker,因为机器上安装了wsl1,docker安装后启动不了,通过询问deepseek发现docker只能在wsl2上安装,因此就想着将本机的wsl1升级到wsl2。 确保你的 Windows 系统是 Windows 10(版本 1903 及以上&…...
392. 判断子序列
https://leetcode.cn/problems/is-subsequence/?envTypestudy-plan-v2&envIdtop-interview-150因为是子序列我们只要关心后一个字符在前一个字符后面出现过就行,至于在哪出现出现几次我们不关心,所以我们可以用HashMap<Character, ArrayList<…...
在 VMware 中为 Ubuntu 24.04 虚拟机设置共享文件夹后,在虚拟机中未能看到共享的内容
在 VMware 中为 Ubuntu 24.04 虚拟机设置共享文件夹后,如果在虚拟机中未能看到共享的内容,可能是由于以下原因: VMware Tools 未正确安装:共享文件夹功能依赖于 VMware Tools 或 Open VM Tools。如果未安装或安装不完整࿰…...
台式电脑插入耳机没有声音或麦克风不管用
目录 一、如何确定插孔对应功能1.常见音频插孔颜色及功能2.如何确认电脑插孔?3.常见问题二、 解决方案1. 检查耳机连接和设备选择2. 检查音量设置和静音状态3. 更新或重新安装声卡驱动4. 检查默认音频格式5. 禁用音频增强功能6. 排查硬件问题7. 检查系统服务8. BIOS设置(可选…...
Windchill开发-WTContainer相关API整理
Windchill开发-WTContainer相关API整理 概述各容器对象相关方法站点容器组织容器产品容器/存储库容器上下文团队角色组 文件夹 方法汇总 概述 Windchill 的环境由一组容器组成,容器分为三级:第一级为站点容器,第二级为组织容器,第…...
理解JSON-RPC 2.0 协议
JSON-RPC 2.0是指一种基于 JSON 的远程过程调用协议,用于在网络上进行跨平台和跨语言的通信。它提供了一种简单、轻量级的方式来实现客户端和服务器之间的方法调用和数据交换。在原文中,JSON-RPC 2.0被用来描述 STDIO 传输机制中消息的格式,即…...
【 C# 使用 MiniExcel 库的典型场景】
以下是 C# 使用 MiniExcel 库的典型场景及代码示例: 一、基础读取操作 强类型读取(需定义数据模型类) 定义与 Excel 列名匹配的类后直接映射为对象集合: csharp Copy Code public class UserAccount { public int Id { get; …...
创建 Pod 失败,运行时报错 no space left on device?
遇到创建Pod失败并报错“no space left on device”时,请按照以下步骤排查和解决问题: 1. 定位问题来源 查看Pod事件: kubectl describe pod <pod-name> -n <namespace> 在输出中查找 Events 部分,确认错误是否与…...
[leetcode]查询区间内的所有素数
一.暴力求解 #include<iostream> #include<vector> using namespace std; vector<int> result; bool isPrime(int i) { if (i < 2) return false; for (int j 2;j * j < i;j) { if (i % j 0) { …...
【Web安全】如何在 CDN 干扰下精准检测 SSRF?Nuclei + Interactsh 实战
❤️博客主页: iknow181 🔥系列专栏: 网络安全、 Python、JavaSE、JavaWeb、CCNP 🎉欢迎大家点赞👍收藏⭐评论✍ 背景 在日常漏洞复核中,我们常用 DNSLog 平台判断目标是否存在 SSRF 漏洞:只要请…...
输入框只能输入非中文字符
在 Qt 中,可以通过设置输入法过滤器(QInputContext)或使用正则表达式来限制输入框(QLineEdit 或 QTextEdit)只能输入非中文字符。以下是两种实现方法: ### 方法 1:使用正则表达式 可以通过 QLi…...
LeeCode 136. 只出现一次的数字
给你一个 非空 整数数组 nums ,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。 你必须设计并实现线性时间复杂度的算法来解决此问题,且该算法只使用常量额外空间。 示例 1 : 输入࿱…...
Traefik应用:配置容器多个网络时无法访问问题
Traefik应用:配置容器多个网络时无法访问问题 介绍解决方法问题原因: **容器多网络归属导致 Traefik 无法正确发现路由规则**。解决方案方法 1:将应用容器 **仅连接** 到 traefik-public 网络方法 2:显式指定 Traefik 监听的网络 …...
超便捷超实用的文档处理工具,PDF排序,功能强大,应用广泛,无需下载,在线使用,简单易用快捷!
小白工具https://www.xiaobaitool.net/files/pdf-sort/ 中的 PDF 排序功能是一项便捷实用的文档处理服务,以下是其具体介绍: 操作便捷直观:用户上传 PDF 文件后,可通过直接拖动页面缩略图来调整顺序,就像在纸质文档中…...
zsh: command not found - 鸿蒙 HarmonyOS Next
终端中执行 hdc 命令抛出如下错误; zsh: command not found 解决办法 首先,查找到 DevEco-Studio 的 toolchains 目录路径; 其次,按照类似如下的文件夹层级结果推理到 toolchains 子级路径下,其中 sdk 后一级的路径可能会存在差异,以实际本地路径结构为主,直至找到 openharm…...
【动态规划】 深入动态规划—两个数组的dp问题
文章目录 前言例题一、最长公共子序列二、不相交的线三、不同的子序列四、通配符匹配五、交错字符串六、两个字符串的最小ASCII删除和七、最长重复子数组 结语 前言 问题本质 它主要围绕着给定的两个数组展开,旨在通过对这两个数组元素间关系的分析,找出…...
金融数据分析(Python)个人学习笔记(7):网络数据采集以及FNN分类
一、网络数据采集 证券宝是一个免费、开源的证券数据平台(无需注册),提供大盘准确、完整的证券历史行情数据、上市公司财务数据等,通过python API获取证券数据信息。 1. 安装并导入第三方依赖库 baostock 在命令提示符中运行&…...
指定运行级别
linux系统下有7种运行级别,我们需要来了解一下常用的运行级别,方便我们熟悉以后的部署环境,话不多说,来看. 开机流程: 指定数级别 基本介绍 运行级别说明: 0:关机 相当于shutdown -h now ⭐️默认参数不能设置为0,否则系统无法正常启动 1:单用户(用于找回丢…...