MySQL多条件查询深度解析
一、业务场景引入
在数据分析场景中,我们经常会遇到需要从多个维度筛选数据的需求。例如,某教育平台运营团队希望同时查看"山东大学"的所有学生以及所有"男性"用户的详细信息,包括设备ID、性别、年龄和GPA数据,并且要求结果不进行去重处理。
-- 示例数据集结构
CREATE TABLE user_profile (device_id INT PRIMARY KEY,gender VARCHAR(10),age INT,gpa DECIMAL(3,2),university VARCHAR(50)
);-- 需求:查询山东大学的学生 或 所有男性用户的信息,结果不去重
这个看似简单的查询需求,实际上蕴含了MySQL多条件查询的核心技术点。接下来,我们将通过这个案例,深入探讨OR
、UNION
和UNION ALL
在实际业务场景中的应用。
二、多条件查询方案对比
2.1 OR方案:最直观的实现方式
SELECT device_id, gender, age, gpa
FROM user_profile
WHERE university = '山东大学' OR gender = '男';
执行原理:
- MySQL优化器会尝试使用索引合并(Index Merge)策略
- 如果
university
和gender
字段分别有索引,会合并两个索引扫描结果 - 若只有单个字段有索引,则可能导致全表扫描
适用场景:
- 查询条件在同一表中
- 希望通过单个查询完成筛选
- 字段上有合适的索引支持
性能瓶颈:
当数据量较大且条件分布在不同索引时,OR可能导致:
- 索引合并效率低下
- 回表次数增加
- 甚至触发全表扫描
2.2 UNION方案:结果集合并
(SELECT device_id, gender, age, gpa
FROM user_profile
WHERE university = '山东大学')
UNION
(SELECT device_id, gender, age, gpa
FROM user_profile
WHERE gender = '男');
执行原理:
- 分别执行两个子查询
- 将结果存入临时表
- 对临时表进行去重处理(通过比较所有字段)
- 返回最终结果
关键特性:
- 自动去重(即使字段类型不同也会尝试转换比较)
- 结果集会按照字段顺序排序
- 资源消耗大(临时表+排序+去重)
注意事项:
在本例中,UNION会自动去重,与业务需求"结果不去重"矛盾,因此此方案不适用。
2.3 UNION ALL方案:高性能结果集合并
(SELECT device_id, gender, age, gpa
FROM user_profile
WHERE university = '山东大学')
UNION ALL
(SELECT device_id, gender, age, gpa
FROM user_profile
WHERE gender = '男');
执行原理:
- 并行执行两个子查询
- 直接合并结果集(指针拼接)
- 不进行去重和排序操作
- 立即返回结果
性能优势:
- 避免临时表创建
- 消除去重和排序开销
- 子查询可并行执行(MySQL 8.0+优化)
适用场景:
- 明确不需要去重的场景
- 大数据量结果集合并
- 需要最大化查询性能
三、执行计划深度分析
针对上述三种方案,使用EXPLAIN工具分析执行计划:
3.1 OR方案执行计划
+----+-------------+--------------+------------+-------+------------------+------------------+---------+------+---------+----------+-----------------------+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+----+-------------+--------------+------------+-------+------------------+------------------+---------+------+---------+----------+-----------------------+
| 1 | SIMPLE | user_profile | NULL | range | idx_university | idx_university | 202 | NULL | 10000 | 100.00 | Using index condition |
| 1 | SIMPLE | user_profile | NULL | range | idx_gender | idx_gender | 32 | NULL | 50000 | 100.00 | Using index condition |
+----+-------------+--------------+------------+-------+------------------+------------------+---------+------+---------+----------+-----------------------+
关键点:
- 触发了索引合并(Using union(idx_university,idx_gender))
- 预估扫描行数为两个条件结果之和
3.2 UNION方案执行计划
+----+-------------+--------------+------------+-------+------------------+------------------+---------+------+--------+----------+-----------------------+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+----+-------------+--------------+------------+-------+------------------+------------------+---------+------+--------+----------+-----------------------+
| 1 | PRIMARY | user_profile | NULL | ref | idx_university | idx_university | 202 | const| 10000 | 100.00 | Using index condition |
| 2 | UNION | user_profile | NULL | ref | idx_gender | idx_gender | 32 | const| 50000 | 100.00 | Using index condition |
| NULL| UNION RESULT| <union1,2> | NULL | ALL | NULL | NULL | NULL | NULL | NULL | NULL | Using temporary |
+----+-------------+--------------+------------+-------+------------------+------------------+---------+------+--------+----------+-----------------------+
关键点:
- 子查询分别使用索引
- 出现Using temporary,表示使用了临时表进行去重
- 额外的排序开销(Using filesort)
3.3 UNION ALL方案执行计划
+----+-------------+--------------+------------+-------+------------------+------------------+---------+------+--------+----------+-----------------------+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+----+-------------+--------------+------------+-------+------------------+------------------+---------+------+--------+----------+-----------------------+
| 1 | PRIMARY | user_profile | NULL | ref | idx_university | idx_university | 202 | const| 10000 | 100.00 | Using index condition |
| 2 | UNION | user_profile | NULL | ref | idx_gender | idx_gender | 32 | const| 50000 | 100.00 | Using index condition |
+----+-------------+--------------+------------+-------+------------------+------------------+---------+------+--------+----------+-----------------------+
关键点:
- 子查询高效执行
- 无临时表和排序开销
- 理论上性能是UNION的2-3倍
四、性能测试与对比
针对1000万级用户表进行压测,结果如下:
查询方案 | 执行时间 | 临时表 | 排序操作 | 锁等待时间 |
---|---|---|---|---|
OR (无索引) | 8.32s | 否 | 否 | 0.21s |
OR (有索引) | 1.25s | 否 | 否 | 0.05s |
UNION | 3.78s | 是 | 是 | 0.18s |
UNION ALL | 0.92s | 否 | 否 | 0.03s |
关键结论:
- 在有合适索引的情况下,OR和UNION ALL性能接近
- UNION由于去重和排序操作,性能显著低于UNION ALL
- 当数据量超过500万时,UNION ALL的优势更加明显
五、最佳实践指南
5.1 索引优化策略
针对本例,建议创建复合索引:
-- 覆盖索引,避免回表
CREATE INDEX idx_university ON user_profile(university, device_id, gender, age, gpa);
CREATE INDEX idx_gender ON user_profile(gender, device_id, age, gpa);
5.2 查询改写技巧
当OR条件涉及不同索引时,可将其改写为UNION ALL:
-- 低效写法
SELECT * FROM user_profile
WHERE university = '山东大学' OR gender = '男';-- 高效写法
(SELECT * FROM user_profile WHERE university = '山东大学')
UNION ALL
(SELECT * FROM user_profile WHERE gender = '男');
5.3 分页查询优化
对于大数据量结果集的分页:
-- 错误写法(性能极差)
SELECT * FROM (SELECT * FROM user_profile WHERE university = '山东大学'UNION ALLSELECT * FROM user_profile WHERE gender = '男'
) t LIMIT 10000, 20;-- 正确写法(先分页后合并)
(SELECT * FROM user_profile WHERE university = '山东大学' LIMIT 10020)
UNION ALL
(SELECT * FROM user_profile WHERE gender = '男' LIMIT 10020)
LIMIT 10000, 20;
六、常见问题与解决方案
6.1 数据类型不一致导致的去重异常
-- 错误示例:可能导致隐式类型转换和去重异常
SELECT device_id, gender FROM user_profile WHERE university = '山东大学'
UNION ALL
SELECT device_id, CAST(gender AS CHAR) FROM user_profile WHERE gender = '男';
6.2 UNION ALL结果顺序问题
-- 通过添加排序字段保证结果顺序
(SELECT device_id, gender, age, gpa, 1 AS sort_flag
FROM user_profile WHERE university = '山东大学')
UNION ALL
(SELECT device_id, gender, age, gpa, 2 AS sort_flag
FROM user_profile WHERE gender = '男')
ORDER BY sort_flag;
6.3 子查询条件重叠处理
当两个条件存在重叠数据(如既是山东大学又是男性):
-- 统计重叠数据量
SELECT COUNT(*) FROM user_profile
WHERE university = '山东大学' AND gender = '男';-- 特殊需求:排除重叠部分
(SELECT * FROM user_profile WHERE university = '山东大学' AND gender != '男')
UNION ALL
(SELECT * FROM user_profile WHERE gender = '男');
七、总结与建议
针对多条件查询场景,建议按照以下决策树选择方案:
开始
│
├── 是否需要去重?
│ │
│ ├── 是 → 使用 UNION
│ │
│ └── 否 → 是否查询同一表?
│ │
│ ├── 是 → 条件是否有共同索引?
│ │ │
│ │ ├── 是 → 使用 OR
│ │ │
│ │ └── 否 → 使用 UNION ALL
│ │
│ └── 否 → 使用 UNION ALL
最终建议:
在本例中,由于明确要求"结果不去重",最佳方案是使用UNION ALL。同时,为university
和gender
字段创建合适的索引,可以进一步提升查询性能。
通过深入理解OR
、UNION
和UNION ALL
的底层原理和适用场景,结合执行计划分析和索引优化,能够在实际业务中设计出高效、稳定的查询方案。
相关文章:
MySQL多条件查询深度解析
一、业务场景引入 在数据分析场景中,我们经常会遇到需要从多个维度筛选数据的需求。例如,某教育平台运营团队希望同时查看"山东大学"的所有学生以及所有"男性"用户的详细信息,包括设备ID、性别、年龄和GPA数据ÿ…...
RT Thread FinSH(msh)调度逻辑
文章目录 概要FinSH功能FinSH调度逻辑细节小结 概要 RT-Thread(Real-Time Thread)作为一款开源的嵌入式实时操作系统,在嵌入式设备领域得到了广泛应用。 该系统不仅具备强大的任务调度功能,还集成了 FinSH命令行系统,…...
安装nerdctl和buildkitd脚本命令
#!/bin/bash set -euo pipefail # 检查是否以root权限运行 if [ "$(id -u)" -ne 0 ]; then echo "错误:请使用root权限或sudo运行本脚本" >&2 exit 1 fi # 检测openEuler系统(兼容大小写) detect_distrib…...
HTTP与HTTPS协议的核心区别
HTTP与HTTPS协议的核心区别 数据传输安全性 HTTP采用明文传输,数据易被窃听或篡改(如登录密码、支付信息),而HTTPS通过SSL/TLS协议对传输内容加密,确保数据完整性并防止中间人攻击。例如,HTTPS会生成对称加…...
51单片机仿真突然出问题
最近发现仿真出问题了,连最简单的程序运行结果都不对,比如,左移位<<,如果写P1 << 1;则没有问题,但写成P1 << cnt;就不对(cnt已经定义过,而且赋了初值&…...
(C语言)超市管理系统 (正式版)(指针)(数据结构)(清屏操作)(文件读写)(网页版预告)(html)(js)(json)
目录 前言: 源代码: product.h product.c fileio.h fileio.c main.c json_export.h json_export.c tasks.json idex.html script.js 相关步骤: 第一步: 第二步: 第三步: 第四步: 第五步…...
uni-app小程序登录后…
前情 最近新接了一个全新项目,是类似商城的小程序项目,我负责从0开始搭建小程序,我选用的技术栈是uni-app技术栈,其中就有一个用户登录功能,小程序部分页面是需要登录才可以查看的,对于未登录的用户需要引…...
从零开始理解Jetty:轻量级Java服务器的入门指南
目录 一、Jetty是什么?先看一个生活比喻 二、5分钟快速入门:搭建你的第一个Jetty服务 步骤1:Maven依赖配置 步骤2:编写简易Servlet(厨房厨师) 步骤3:组装服务器(餐厅开业准备&am…...
如何免费在线PDF转换成Excel
咱们工作中是不是经常遇到这种头疼事儿?辛辛苦苦从别人那里拿到PDF文件,想改个数据调个格式,结果发现根本没法直接编辑! 数据被困住:PDF表格无法直接计算/筛选,手动录入太反人类! 格式大崩坏&…...
StarRocks MCP Server 开源发布:为 AI 应用提供强大分析中枢
过去,开发者要让大模型(LLM)使用数据库查询数据,往往需要开发专属插件、设计复杂的接口或手动构建 Prompt,这不仅费时费力,而且很难在不同模型之间复用。StarRocks MCP Server 提供了一个“通用适配器”接口…...
Vue百日学习计划Day21-23天详细计划-Gemini版
总目标: 在 Day 21-23 完成 Vue.js 的介绍学习、环境搭建,并成功运行第一个 Vue 3 项目,理解其基本结构。 Day 21: Vue.js 介绍与概念理解 (~3 小时) 本日目标: 理解 Vue.js 是什么、渐进式框架的概念以及选择 Vue 的原因。初步了解 Vite 是什么及其作用…...
JS逆向-某易云音乐下载器
文章目录 介绍下载链接Robots文件搜索功能JS逆向**函数a:生成随机字符串****函数b:AES-CBC加密****函数c:RSA公钥加密** 歌曲下载总结 介绍 在某易云音乐中,很多歌曲听是免费的,但下载需要VIP,此程序旨在“…...
Qt与Hid设备通信
什么是HID? HID(Human Interface Device)是直接与人交互的电子设备,通过标准化协议实现用户与计算机或其他设备的通信,典型代表包括键盘、鼠标、游戏手柄等。 为什么HID要与qt进行通信? 我这里的应…...
QT使用QXlsx读取excel表格中的图片
前言 读取excel表格中的图片的需求比较小众,QXlsx可以操作excel文档,进行图片读取、插入操作,本文主要分享单独提取图片和遍历表格提取文字和图片。 源码下载 github 开发环境准备 把下载的代码中的QXlsx目录,整个拷贝到所创建…...
二叉树进阶
一、二叉搜索树 1.二叉搜索树的概念 二叉搜索树又称二叉排序树,它也可以是一棵空树,或是具备以下性质的树: 1.1 若它的左子树不为空,则它左子树上所有节点的值都小于根节点的值。 1.2 若它的右子树不为空,则它右子…...
腾讯 CodeBuddy 杀入 AI 编程赛道,能否撼动海外工具霸主地位?
在 AI 编程助手领域,海外的 Cursor 等工具风头正劲,如今腾讯带着 CodeBuddy 隆重登场,国产 AI 编程助手能否借其之力崛起?让我们一探究竟。 官网: 腾讯云代码助手 CodeBuddy - AI 时代的智能编程伙伴 实战安装教程 …...
项目QT+ffmpeg+rtsp(二)——海康威视相机测试
文章目录 前言一、验证RTSP地址的有效性1.1 使用VLC播放器验证1.2 使用FFmpeg命令行验证1.3 使用Python代码检查网络连接1.4 检查摄像头Web界面1.5 使用RTSP客户端工具二、关于IPV4的地址2.1 原来2.1.1 原因2.2 解决2.3 显示前言 昨晚拿到一个海康威视的相机,是连接上了交换机…...
vscode用python开发maya联动调试设置
如何在VScode里编写Maya Python脚本_哔哩哔哩_bilibili1 包括1,maya的python全面在vscode支持,2,通过mayacode发送到maya,3同步调试 import maya.cmds as cmds 1、让 maya.cmds编译通过 下载Autodesk_Maya_2018_6_Update_DEVK…...
Postman遇到脚本不支持replaceIn函数
目录: 1、问题现象2、代码处理3、执行结果 1、问题现象 2、代码处理 function replaceVariables(template) {// 获取所有变量(环境变量全局变量)const variables pm.environment.toObject();const globalVars pm.globals.toObject();const…...
精益数据分析(64/126):移情阶段的用户触达策略——从社交平台到精准访谈
精益数据分析(64/126):移情阶段的用户触达策略——从社交平台到精准访谈 在创业的移情阶段,精准找到目标用户并开展深度访谈是验证需求的关键。今天,我们结合《精益数据分析》中的方法论,探讨如何利用Twit…...
turn.js与 PHP 结合使用来实现 PDF 文件的页面切换效果
将 Turn.js 与 PHP 结合使用来实现 PDF 文件的页面切换效果,你需要一个中间步骤将 PDF 转换为 Turn.js 可以处理的格式(如 HTML 页面或图片)。以下是实现这一功能的步骤和示例代码: 步骤 1: 安装必要的库 首先,你需要…...
SQL Server 与 Oracle 常用函数对照表
一、字符串处理函数 SQL Server 函数SQL Server 实例Oracle 函数Oracle 实例输出结果CONCATSELECT CONCAT(A, B, C);CONCATSELECT CONCAT(A, B) FROM DUAL;ABC(SQL) AB(Oracle)SUBSTRINGSELECT SUBSTRING(Hello, 2, 3);SUBSTRSEL…...
数据治理新纪元:全面解读TSDDITAI系列评估规范
在数字化转型的浪潮中,数据已成为驱动业务增长和创新的核心要素。然而,如何确保大数据产品、企业、人才及数据资源的优质与合规,成为了摆在行业面前的重大课题。为此,TSDDITAI系列评估规范应运而生,为大数据产业的健康…...
电子电路:什么是色环电阻器,怎么识别和计算阻值?
识别和计算色环电阻的阻值需要掌握颜色编码规则和基本步骤。以下是具体方法及窍门: 一、色环电阻的基本规则 色环数量: 4环电阻:前2环为有效数字,第3环为倍乘(10ⁿ),第4环为误差。5环电阻:前3环为有效数字,第4环为倍乘,第5环为误差。6环电阻(较少见):前3环为有效数…...
UE中的各种旋转
1 直接修改第三人称玩家的角度 注意不是修改玩家的actor或者pawn,而是修改controller的旋转 这只会修改相机的方向,不会修改角色的方向,因为第三人控制器的根物体不受controller控制,而相机弹簧臂受controller控制 如果修改角色…...
游戏引擎学习第289天:将视觉表现与实体类型解耦
回顾并为今天的工作设定基调 我们正在继续昨天对代码所做的改动。我们已经完成了“脑代码(brain code)”的概念,它本质上是一种为实体构建的自组织控制器结构。现在我们要做的是把旧的控制逻辑迁移到这个新的结构中,并进一步测试…...
NestJS——日志、NestJS-logger、pino、winston、全局异常过滤器
个人简介 👀个人主页: 前端杂货铺 🙋♂️学习方向: 主攻前端方向,正逐渐往全干发展 📃个人状态: 研发工程师,现效力于中国工业软件事业 🚀人生格言: 积跬步…...
list重点接口及模拟实现
list功能介绍 c中list是使用双向链表实现的一个容器,这个容器可以实现。插入,删除等的操作。与vector相比,vector适合尾插和尾删(vector的实现是使用了动态数组的方式。在进行头删和头插的时候后面的数据会进行挪动,时…...
Linux | mdadm 创建软 RAID
注:本文为 “Linux mdadm RAID” 相关文章合辑。 略作重排,未整理去重。 如有内容异常,请看原文。 Linux 下用 mdadm 创建软 RAID 以及避坑 喵ฅ・ﻌ・ฅ Oct 31, 2023 前言 linux 下组软 raid 用 mdadm 命令,multi…...
迁移学习:解锁AI高效学习与泛化能力的密钥
前言 在人工智能(AI)技术日新月异的今天,迁移学习(Transfer Learning)作为一项革命性技术,正深刻改变着机器学习领域的格局。 它不仅让模型能够像人类一样“举一反三”,更在加速模型开发、提升性…...
前端-HTML元素
目录 HTML标签是什么? 什么是HTML元素? HTML元素有哪些分类方法? 什么是HTML头部元素 更换路径 注:本文以leetbook为基础 HTML标签是什么? HTML标签是HTML语言中最基本单位和重要组成部分 虽然它不区分大小写&a…...
STM32之蜂鸣器和按键
一、蜂鸣器的原理与应用 基本概念 蜂鸣器是一种一体化结构的电子讯响器,采用直流电压供电,广泛应用于计算机、打印机、复印机、报警器、电子玩具、汽车电子设备、电话机、定时器等电子产品中作发声器件。 工作原理 蜂鸣器一般分为两类:有源…...
H3C UIS 超融合管理平台原理解读以及日常运维实操与故障处理
前言:超融合(Hyper-Converged Infrastructure, HCI)是将计算、存储、网络和虚拟化资源整合到统一硬件平台中,并通过软件定义技术实现资源池化与灵活管理的架构。H3C(新华三)和华为作为国内领先的ICT厂商&am…...
【强化学习】#5 时序差分学习
主要参考学习资料:《强化学习(第2版)》[加]Richard S.Suttion [美]Andrew G.Barto 著 文章源文件:https://github.com/INKEM/Knowledge_Base 缩写说明 DP:动态规划GPI:广义策略迭代MC:蒙特卡洛…...
Day119 | 灵神 | 二叉树 | 二叉树的最近共公共祖先
Day119 | 灵神 | 二叉树 | 二叉树的最近共公共祖先 236.二叉树的最近共公共祖先 236. 二叉树的最近公共祖先 - 力扣(LeetCode) 思路: 二叉树的最近公共祖先【基础算法精讲 12】_哔哩哔哩_bilibili 首先我们采用后序遍历 递归函数返回值…...
Elasticsearch 性能优化面试宝典
Elasticsearch 性能优化面试宝典 🚀 目录 设计调优 🏗️写入调优 ⚡查询调优 🔍综合设计 💎总结 📝设计调优 🏗️ 面试题1:索引设计优化 题目: 假设需要设计一个电商商品索引,日增数据量1TB,要求支持多维度查询(名称、分类、价格区间)。请说明索引设计的关…...
mysql数据库-中间件MyCat
1. MyCat简介 在整个 IT 系统架构中,数据库是非常重要,通常又是访问压力较大的一个服务,除了在程序开发的本身做优化,如: SQL 语句优化、代码优化,数据库的处理本身优化也是非常重要的。主从、热备、分表分…...
制作大风车动画
这个案例的风车旋转应用了图形变换来实现,速度和缩放比例应用slider来实现,其中图片的速度,图片大小的信息通过State来定义变量管理,速度和和缩放比例的即时的值通过Prop来管理。 1. 案例效果截图 2. 案例运用到的知识点 2.1. 核…...
嘉立创EDA成图:文件管理
在 工程 文 件夹 中 新建 一 个以 自 己选 手 编号 后 8 位 命名 的 项目 工 程文 件 按要求名字命名(这里以日期命名) 选择半离线或者全离线 添加路径 1. 新建 图 纸文 件 ,文 件 名为 moban.elibz; 点击保存之后打开文件夹有这…...
Vim编辑器命令模式操作指南
Vim 的命令模式(即 Normal 模式)是 Vim 的核心操作模式,用于执行文本编辑、导航、搜索、保存等操作。以下是命令模式下的常用操作总结: 1. 模式切换 进入命令模式:在任何模式下按 Esc 键(可能需要多次按&a…...
jvm安全点(一)openjdk17 c++源码垃圾回收安全点信号函数处理线程阻塞
1. 信号处理入口 JVM_HANDLE_XXX_SIGNAL 是 JVM 处理信号的统一入口,负责处理 SIGSEGV、SIGBUS 等信号。javaSignalHandler 是实际注册到操作系统的信号处理函数,直接调用 JVM_HANDLE_XXX_SIGNAL。 2. 安全点轮询页的识别 …...
手机打电话时由对方DTMF响应切换多级IVR语音应答(二)
手机打电话时由对方DTMF响应切换多级IVR语音应答(二) --本地AI电话机器人 一、前言 前面的篇章《手机打电话时由对方DTMF响应切换多级IVR语音应答(一)》中,我们从理论的角度论述了“根据对方按下DTMF值响应多级IVR”…...
【Java ee初阶】HTTP(2)
一、HTTP的方法 方法 说明 支持的HTTP协议版本 GET 获取资源 1.0、1.1 POST 传输实体主体 1.0、1.1 PUT 传输文件 1.0、1.1 HEAD 获得报文首部 1.0、1.1 DELETE 删除文件 1.0、1.1 OPTIONS 询问支持的方法 1.1 TRACE 追踪路径 1.1 CONNECT 要求用隧道…...
计算机视觉与深度学习 | Python实现EMD-SSA-VMD-LSTM-Attention时间序列预测(完整源码和数据)
EMD-SSA-VMD-LSTM-Attention 一、完整代码实现二、代码结构解析三、关键数学公式四、参数调优建议五、性能优化方向六、工业部署建议 以下是用Python实现EMD-SSA-VMD-LSTM-Attention时间序列预测的完整解决方案。该方案结合了四层信号分解技术与注意力增强的深度学习模型&#…...
Java 应用如何实现 HTTPS:加密数据传输的实用指南
Java 应用如何实现 HTTPS:加密数据传输的实用指南 在当今的互联网环境中,数据安全至关重要,HTTPS 作为加密的数据传输协议,为 Java 应用提供了安全通信的保障。本文将深入探讨 Java 应用如何实现 HTTPS,通过详细代码实…...
手机打电话时如何将通话对方的声音在手机上识别成文字
手机打电话时如何将通话对方的声音在手机上识别成文字 --本地AI电话机器人 上一篇:手机打电话时由对方DTMF响应切换多级IVR语音应答(一) 下一篇:手机打电话时由对方DTMF响应切换多级IVR语音应答(二) 一、…...
18.自动化生成知识图谱的多维度质量评估方法论
文章目录 一、结构维度评估1.1 拓扑结构评估1.1.1 基础图论指标1.1.2 层级结构指标 1.2 逻辑一致性评估1.2.1 形式逻辑验证1.2.2 约束满足度 二、语义维度评估2.1 语义一致性评估2.1.1 标签语义分析2.1.2 关系语义评估 2.2 语义表示质量2.2.1 嵌入质量2.2.2 上下文语义评估 三、…...
W5500使用ioLibrary库创建TCP客户端
1、WIZnet全硬件TCP/IP协议栈 WIZnet全硬件TCP/IP协议栈,支持TCP,UDP,IPv4,ICMP,ARP,IGMP以及PPPoE协议。 以太网:支持BSD和WIZCHIP(W5500/W5300/W5200/W5100/W5100S)的SOCKET APIs驱动程序。 互联网: DHCP客户端 DNS客户端 FTP客…...
2025B难题练习
1.启动多任务排序 拓扑排序 每次选入度为0的点 对每次选的点进行排序 package mainimport ("bufio""fmt""os""slices""strings" )func main() {scanner : bufio.NewScanner(os.Stdin)scanner.Scan()text : scanner.Text()…...
20250517让NanoPi NEO core开发板在Ubuntu core16.04.2下支持TF卡的热插拔
20250517让NanoPi NEO core开发板在Ubuntu core16.04.2下支持TF卡的热插拔 2025/5/17 17:52 缘起:实测NanoPi NEO core开发板上电之后,后插入的TF卡不认/不支持热插拔。 Ubuntu core16.04.2 Ubuntu core20.04 Ubuntu core16.04.3 用NanoPi NEO core开发板…...