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

SQL:JOIN 进阶

目录

JOIN 是什么?

 🔹OUTER JOIN(外连接)

外连接的分类

外连接与内连接的区别

🔹USING 子句 

语法结构

 和 ON 的对比

📘USING 的内部逻辑 

🧩 多个字段的 USING

USING 的 SELECT 特性(字段可见性)

配合 JOIN 类型的效果

🔹NATURAL JOIN(自然连接)

基本语法:

🔄 执行机制

🔍 对比示例

隐藏风险 ⚠️ 

字段选择行为(结果特征)

自然连接的变体语法(扩展)

NATURAL JOIN vs USING vs ON

🧩 JOIN 的本质回顾:有条件的笛卡尔积


JOIN 是什么?

JOIN 本质上是“笛卡尔积 + 条件筛选”。

在关系数据库中,两个表的连接最原始的操作就是笛卡尔积,即将表 A 和表 B 的所有行做组合,然后通过连接条件筛选我们真正需要的数据。

本篇文章将从以下几个方面,带你走进 JOIN 的进阶世界:

  • 外连接的完整逻辑

  • 更优雅的连接方式:USING 子句

  • 自动化但需谨慎使用的 NATURAL JOIN


 🔹OUTER JOIN(外连接)

在实际开发中,我们常常使用 INNER JOIN 来筛选匹配成功的数据行。然而,这种连接方式默认忽

略未匹配的记录,在某些业务场景(如数据缺失分析、审计对比、错误检测)中反而是不利的。 

外连接是一种可以保留未匹配记录的连接方式,它不仅保留匹配成功的行,还会保留某一方或双方

表中未能匹配的行,并对缺失部分用 NULL 补全。 

外连接的分类

类型含义说明
LEFT OUTER JOIN保留左表所有记录,右表无法匹配的补 NULL
RIGHT OUTER JOIN保留右表所有记录,左表无法匹配的补 NULL
FULL OUTER JOIN保留左右两表所有记录,无法匹配部分用 NULL 补全

📌 注意:通常 SQL 中 OUTER 关键字可以省略。

外连接与内连接的区别

比较维度INNER JOINOUTER JOIN(LEFT/RIGHT/FULL)
匹配条件只保留匹配成功的行匹配成功 + 不匹配的行(补 NULL)
连接结果小于等于原始行数大于等于参与表的行数
典型使用场景严格一一匹配需求需要查看未关联数据

⚠️ MySQL 不直接支持 FULL OUTER JOIN 


 

🔹USING 子句 

我们在之前的 JOIN 中,经常会写出类似 ON a.id = b.id 的重复性语句。USING 是一种语法糖,

当连接字段在两个表中字段名完全一致时,它可以大幅度简化写法。

USING 子句是 JOIN 中的语法简写,用于当连接字段在两个表中字段名相同时,代替 ON a.col = b.col 的写法。

语法结构

SELECT column_list
FROM table1
JOIN table2
USING (column_name);

多个字段:

SELECT column_list
FROM table1
JOIN table2
USING (column1, column2);

🔸 支持:INNER JOINLEFT JOINRIGHT JOINFULL OUTER JOIN
🔸 不支持:CROSS JOIN(因为它没有连接条件)

⚠️ 注意事项

  1. USING 中指定的字段必须在两个表中都存在且字段名一致

  2. 仅支持等值连接(=

  3. SELECT 出来的结果中,这些字段只会显示一次(不是 table1.col 和 table2.col,而是一个简化字段)

 和 ON 的对比

使用 ON 的写法:

SELECT *
FROM employees e
JOIN departments d
ON e.dept_id = d.dept_id;

等价的 USING 写法:

SELECT *
FROM employees
JOIN departments
USING (dept_id);

💡 两者效果一致,差异是:

  • ON 写法结果中会保留 e.dept_idd.dept_id 两列;

  • USING 写法只保留一列 dept_id,更整洁。

📘USING 的内部逻辑 

在执行阶段,SQL 引擎会将:

JOIN USING (col)

转换为:

JOIN ON table1.col = table2.col

然后只保留一个 col 字段,不显示来源表名。

🧩 多个字段的 USING

你可以使用多个字段作为连接条件(必须字段名都一样):

SELECT *
FROM orders o
JOIN deliveries d
USING (order_id, delivery_date);

 这相当于:

ON o.order_id = d.order_id AND o.delivery_date = d.delivery_date

USING 的 SELECT 特性(字段可见性)

考虑如下例子:

SELECT *
FROM employees
JOIN departments
USING (dept_id);

结果中:

  • dept_id 只出现一次

  • 你不能在 SELECT 中写 employees.dept_iddepartments.dept_id,会报错

💡 所以在使用 USING 时,如果你需要区分字段来源,就不要用 USING,用 ON 更灵活

配合 JOIN 类型的效果

JOIN 类型是否支持 USING非匹配字段是否保留输出字段
INNER JOIN公共字段只显示一次
LEFT JOIN左表全部保留同上
RIGHT JOIN右表全部保留同上
FULL OUTER JOIN✅(部分数据库)两表全部保留同上

🔹NATURAL JOIN(自然连接)

NATURAL JOIN 是一种自动基于两个表中相同列名进行连接的语法,无需显式指定连接条件。 

基本语法:

SELECT column_list
FROM table1
NATURAL JOIN table2;

支持的连接类型有:

  • NATURAL JOIN(即自然内连接)

  • NATURAL LEFT JOIN

  • NATURAL RIGHT JOIN

  • NATURAL FULL OUTER JOIN(部分数据库支持)

🔄 执行机制

自然连接的执行过程分为三步:

  1. 自动识别两个表中字段名相同的列

  2. 对这些列执行等值连接(相当于 ON a.col = b.col)

  3. 结果中只保留一份这些列,不重复显示

 注意:这是隐式行为,你无法控制哪些字段被用于连接,只要名字一样,它就会加入连接条件中。

🔍 对比示例

我们以两个表为例:

表A:students

id

name

class_id

1

Alice

101

2

Bob

102

表B:classes

class_idteacher
101Zhang
102Wang

 使用 NATURAL JOIN:

SELECT *
FROM students
NATURAL JOIN classes;

 相当于:

SELECT students.id, students.name, students.class_id, classes.teacher
FROM students
JOIN classes
ON students.class_id = classes.class_id;

但注意:

  • class_id 只显示一列,不是 students.class_idclasses.class_id 两列。

隐藏风险 ⚠️ 

虽然语法简洁,但 NATURAL JOIN 有两个致命隐患:

1️⃣ 字段名意外冲突

如果两个表中存在同名但不相关的列,它们也会被自动用于连接,可能导致:

  • 错误连接逻辑

  • 无结果

  • 数据误导

示例:

-- students 和 exams 表都有 name 字段,但不是用于连接的
SELECT *
FROM students
NATURAL JOIN exams;

这里 name 字段会被用于连接,结果可能完全不符合预期。

2️⃣ 表结构变动敏感

只要某个字段名在两个表中变得相同(或不同),NATURAL JOIN 的行为会自动改变,增加 SQL 的不可预测性与维护难度。

字段选择行为(结果特征)

  • 所有同名字段:只显示一列(不带表前缀)

  • 非同名字段:分别显示原始表字段

自然连接的变体语法(扩展)

类型说明
NATURAL JOIN自然内连接(只返回匹配行)
NATURAL LEFT JOIN左自然外连接(左表全部保留)
NATURAL RIGHT JOIN右自然外连接(右表全部保留)
NATURAL FULL OUTER JOIN全自然外连接(两个表全部保留)

⚠️ FULL OUTER 在 MySQL 中不支持。

NATURAL JOIN vs USING vs ON

特性NATURAL JOINUSING 子句ON 子句
连接字段是否自动识别✅(自动找同名字段)❌(手动指定)❌(完全手动)
是否必须字段名一致✅ 必须一致✅ 仅 USING 中字段需一致❌ 不要求一致
连接条件是否灵活❌ 只能等值❌ 只能等值✅ 任意逻辑、范围比较等
SELECT 中字段出现情况同名字段只出现一次USING 字段只出现一次字段全部保留
可控性❌ 极低✅ 中等✅✅ 极高
推荐使用❌ 不推荐✅ 推荐✅✅ 强烈推荐

🧩 JOIN 的本质回顾:有条件的笛卡尔积

JOIN 的底层其实是生成两个表的笛卡尔积,再通过连接条件进行筛选,不同 JOIN 类型只是在“保留未匹配数据”的策略上不同。

 

相关文章:

SQL:JOIN 进阶

目录 JOIN 是什么? 🔹OUTER JOIN(外连接) 外连接的分类 外连接与内连接的区别 🔹USING 子句 语法结构 和 ON 的对比 📘USING 的内部逻辑 🧩 多个字段的 USING USING 的 SELECT 特性&a…...

SATA—Link层状态机

一、概述 Link层的状态机大致可以分为五类: 链路层空闲状态机通信异常处理状态机链路层发送状态机链路层接收状态机链路层电源管理下的状态机 二、链路层空闲状态机 链路层空闲状态机共包含两个状态L_IDLE、L_SyncEscape,每个状态下的处理机制与条状…...

12.2.2 allocator类

allocator类将分配内存空间、调用构造函数、调用析构函数、释放内存空间这4部分操作分开&#xff0c;全部交给程序员来执行&#xff0c;不像new和delete #include <iostream> #include <string>int main() {const int n 10;std::allocator<std::string> al…...

Qwen:Qwen3,R1 在 Text2SQL 效果评估

【对比模型】 Qwen3 235B-A22B&#xff08;2350亿总参数&#xff0c;220亿激活参数&#xff09;&#xff0c;32B&#xff0c;30B-A3B&#xff1b;QwQ 32B&#xff08;推理模型&#xff09;DeepSeek-R1 671B&#xff08;满血版&#xff09;&#xff08;推理模型&#xff09; 1&a…...

Egg.js知识框架

一、Egg.js 核心概念 1. Egg.js 简介 基于 Koa 的企业级 Node.js 框架&#xff08;阿里开源&#xff09; 约定优于配置&#xff08;Convention over Configuration&#xff09; 插件化架构&#xff0c;内置多进程管理、日志、安全等能力 适合中大型企业应用&#xff0c;提供…...

latex控制表格宽度,不要超出页面

字体控制 控制表格的字体&#xff0c;一般使用 footnotesize &#xff0c;neurips 使用的就是这个大小 列宽距控制 默认列宽距是 6pt &#xff0c;可以人工调节成为 5pt&#xff0c;不影响字体&#xff0c;比较不影响可读性 % 对于 table* 环境, [htbp] 通常比 [h] 或 [h!]…...

Linux进程管理

程序、进程、服务 程序 program 安装包&#xff0c;未运行的代码&#xff0c;APP 存放在磁盘上 进程 process 已运行程序、命令、服务&#xff0c;一个程序可以运行多个进程、父进程启动子进程 运行在内存中 服务 service 一直运行的进程&#xff0c;也叫做守护进程&…...

[springboot]SSM日期数据转换易见问题

日期数据的形式有多种&#xff0c;如2025-05-12 14:46:50、2025.05.12 14:46&#xff0c;可以没有年只有月日...等等。 在SSM项目中&#xff0c;前后端传递日期数据时往往需要统一格式&#xff0c;不然会报数据类型转换异常。 在controller层中用实体类实例对象接收前端服务器传…...

数字IC后端培训教程之数字后端项目典型案例分析

今天给大家分享下最近小编帮助学员解决的几个经典数字IC后端项目问题。希望能够对大家的学习和工作有所帮助。 数字IC后端项目典型问题之后端实战项目问题记录&#xff08;2025.04.24&#xff09; 数字IC后端设计实现培训教程&#xff08;整理版&#xff09; Q1: 老师好&…...

数字ic后端设计从入门到精通4(含fusion compiler, tcl教学)CMOS VLSI Design

Layout Design Rules 一、什么是 Layout Design Rules&#xff1f; 布局设计规则是一套用于指导芯片物理设计的几何约束条件&#xff0c;确保设计可以在特定制造工艺下被正确制造。这些规则通常由代工厂&#xff08;foundry&#xff09;提供&#xff0c;规定了最小线宽、间距、…...

服务器带宽基础知识

服务器带宽基础知识详解 一、带宽的定义与基本概念 服务器带宽&#xff08;Bandwidth&#xff09;是指服务器与互联网之间在单位时间内传输数据的能力&#xff0c;通常以 Mbps&#xff08;兆比特每秒&#xff09; 或 Gbps&#xff08;吉比特每秒&#xff09; 为单位衡量。它决…...

算法-单调栈

739. 每日温度 - 力扣&#xff08;LeetCode&#xff09; 原理&#xff1a;739. 每日温度 - 力扣&#xff08;LeetCode&#xff09; class Solution { public:vector<int> dailyTemperatures(vector<int>& temperatures) {stack<int>sta;int ntemperatu…...

大核极坐标码

大核极性码&#xff08;ℓ>2&#xff09;的SC解码操作与原始极性码相似。迭代地&#xff0c;解码方程可以表示为&#xff1a; 这是给定信道输出的路径的概率。 虽然这些操作类似于传统的极坐标码&#xff0c;但迭代计算概率的复杂性相对于ℓ 作为&#xff0c;这使得它对于非…...

如何避免 JavaScript 中常见的闭包陷阱?

文章目录 1. 引言2. 什么是闭包&#xff1f;3. 常见的闭包陷阱及解决方案3.1 循环中的闭包陷阱3.2 内存泄漏3.3 意外的全局变量3.4 React 中的闭包陷阱 4. 总结 1. 引言 闭包&#xff08;Closure&#xff09;是 JavaScript 中一个强大而常用的特性&#xff0c;它允许函数访问其…...

免费多线程下载工具

先放下载链接&#xff1a;https://tool.nineya.com/s/1ir25buco Free Download Manager&#xff0c;简称“FDM”&#xff0c;是一款多线程下载工具&#xff0c;支持多端使用哦&#xff0c;像Windows、mac Os、Linux、浏览器插件以及安卓端都涵盖在内&#xff0c;这些版本这里都…...

Aware和InitializingBean接口以及@Autowired注解失效分析

Aware 接口用于注入一些与容器相关信息&#xff0c;例如&#xff1a; ​ a. BeanNameAware 注入 Bean 的名字 ​ b. BeanFactoryAware 注入 BeanFactory 容器 ​ c. ApplicationContextAware 注入 ApplicationContext 容器 ​ d. EmbeddedValueResolverAware 注入 解析器&a…...

【NextPilot日志移植】日志写入流程

&#x1f4dd; 文件后端日志写入流程详解 当后端选择文件时&#xff0c;日志写入过程主要涉及 LogWriter 和 LogWriterFile 类的协作。以下是详细的日志写入过程解释及涉及的代码&#xff1a; 1. LogWriter 类初始化 在 LogWriter 类的构造函数中&#xff0c;如果配置的后端…...

OpenCV直方图与直方图均衡化

一、图像直方图基础 1. 什么是图像直方图&#xff1f; 图像直方图是图像处理中最基本且重要的统计工具之一&#xff0c;它用图形化的方式表示图像中像素强度的分布情况。对于数字图像&#xff0c;直方图描述了每个可能的像素强度值&#xff08;0-255&#xff09;在图像中出现…...

Babel进阶:如何自定义插件?

Babel 是一个非常流行的 JavaScript 编译器&#xff0c;下面我们将从零到一编写一个 babel 箭头函数语法转换插件&#xff0c;掌握 babel 插件设计思路与编写规范&#xff0c;需求很简单就是将箭头函数转换为普通函数。 const test ()>{console.log("Hello World!&qu…...

C++中类中const知识应用详解

下面将从**const 成员**、const 成员函数、const 对象、mutable、constexpr 等方面&#xff0c;逐一详解 C 类中常见的 const 用法及注意事项&#xff0c;并配合示例。 一、const 数据成员 必须在初始化列表中初始化 class A {const int x; // const 成员 public:A(int v) :…...

LeetCode 513 找树左下角的值 LeetCode 112 路径总和 LeetCode106 从中序与后序遍历序列构造二叉树

LeetCode 513 找树左下角的值 迭代法——层序遍历 思路&#xff1a;对树进行层序遍历操作&#xff0c;层序遍历完后&#xff0c;输出树最后一层的第一个节点。 # Definition for a binary tree node. # class TreeNode(object): # def __init__(self, val0, leftNone, r…...

电脑端实用软件合集:土拨鼠+Rufus+实时网速监控工具

朋友们好&#xff0c;我是李师傅&#xff01;今天带来三款让人直呼"真香"的电脑工具&#xff0c;它们就像武林高手各怀绝技&#xff0c;保证让你工作效率翻倍&#xff01; 1Tuboshu&#xff08;电脑&#xff09; 最近发现一款神奇工具——Tuboshu&#xff08;发音类…...

杨校老师项目之基于SSM与JSP的鲜花销售系统-【成品设计含文档】

基于SSMJSP鲜花商城系统 随着电子商务的快速发展&#xff0c;鲜花在线销售已成为一种重要的消费模式。本文设计并实现了一个基于JSP技术的鲜花销售管理系统&#xff0c;采用B/S架构&#xff0c;使用SSM框架进行开发&#xff0c;并结合Maven进行项目依赖管理。系统分为前台用户模…...

linux服务器免密脚本分享

#!/bin/bash set -euo pipefail# 基础环境配置 setenforce 0 >/dev/null 2>&1 || true sed -i "s/SELINUXenforcing/SELINUXdisabled/" /etc/selinux/config systemctl stop firewalld >/dev/null 2>&1 || true systemctl disable firewalld >…...

STM32实现循环队列

1. 循环队列的核心结构设计 ​数据结构定义&#xff1a;通常使用结构体封装队列的指针、长度及缓冲区。例如&#xff1a; typedef struct {u16 Head; // 队头指针u16 Tail; // 队尾指针u16 Length; // 当前队列长度u8 Rsv_DAT[50]; // 缓冲区数组 } ringbuff_t; 其中…...

matlab simulink双边反激式变压器锂离子电池均衡系统,双目标均衡策略,仿真模型,提高均衡速度38%

双边反激式变压器锂离子电池均衡系统&#xff0c;双目标均衡策略 锂离子电池均衡系统综述 引言 电池均衡管理系统(Battery Balancing Management System, BBMS)是电池管理系统(BMS)的核心组成部分&#xff0c;主要用于解决电池组中单体电池间的不一致性问题。随着电动汽车、储能…...

数据库笔记(1)

文章目录 1.SQL的通用语法2.四类SQL语句2.1DDL语句2.2.1数据库操作2.1.2表操作 2.2DML语句2.2.1添加数据(INSERT)2.2.2修改数据(UPDATE)2.2.3删除数据(DELETE) 2.3DQL语句2.3.1DQL语法2.3.2基本查询2.3.3条件查询2.3.4分组查询2.3.5排序查询2.3.6分页查询2.3.7DQL语句的执行顺序…...

深入掌握CSS定位:构建精密布局的核心技术

一、定位的定义 定位&#xff08;Positioning&#xff09;是CSS中用于控制元素在网页中的具体位置的一种机制。通过定位&#xff0c;可以将元素放置在页面的任意位置&#xff0c;并控制其与其他元素的层叠关系。 二、定位的特点与作用 自由摆放位置&#xff1a; 允许元素摆放…...

使用达梦数据库官方管理工具SQLark导入与导出数据库表

SQLark 是达梦数据官方自主研发的、一款面向信创应用开发者的数据库开发和管理工具。只需简单注册&#xff0c;即可永久免费使用其客户端功能。该工具支持连接达梦、Oracle、MySQL 等多种数据库&#xff0c;为开发者提供了便捷的跨平台操作体验。通过访问官网 www.sqlark.com&a…...

Linux系统管理与编程19:自动部署dns

兰生幽谷&#xff0c;不为莫服而不芳&#xff1b; 君子行义&#xff0c;不为莫知而止休。 #!/bin/bash #----------------------------------------------------------- #前提条件&#xff1a;准备好虚拟机&#xff0c;①外网内网畅通&#xff0c;②yum源搭建好 # File Name: …...

JavaScript高级进阶(七)

this对象 想知道this对象是什么&#xff0c;我们先来看一段简单的小代码: <style> div{ width: 200px; height: 200px; background-color: skyblue; } </style> </head> <body> <div…...

前端面试每日三题 - Day 32

这是我为准备前端/全栈开发工程师面试整理的第32天每日三题练习&#xff1a; ✅ 题目1&#xff1a;Electron主流架构模式深度解析 核心架构模式对比 模式优点缺点适用场景单一窗口模式开发简单、资源占用低功能扩展受限小型工具类应用多窗口模式模块解耦、独立运行进程管理复…...

MySQL全量,增量备份与恢复

目录 一.MySQL数据库备份概述 1.数据备份的重要性 2.数据库备份类型 3.常见的备份方法 二&#xff1a;数据库完全备份操作 1.物理冷备份与恢复 2.mysqldump 备份与恢复 3.MySQL增量备份与恢复 3.1MySQL增量恢复 3.2MySQL备份案例 三&#xff1a;定制企业备份策略思路…...

摆脱拖延症的详细计划示例

以下是一个以一周为周期&#xff0c;帮助你摆脱拖延症的详细计划示例&#xff0c;你可以根据自己的实际情况进行调整和完善。 --- # 摆脱拖延症一周计划 ## 一、计划目标 通过一系列有针对性的方法和行动&#xff0c;逐步克服拖延习惯&#xff0c;提高任务执行效率和自我管理…...

Linux512 ssh免密登录 ssh配置回顾

下载MX 官网 参考 OK 登个tom试试 然后再计划登个RealServer 计划再用仅主机网卡试试 连不上 看来要通过JumpServer再联 通过网卡访问 被踢掉了 成功通过跳板机JumpServer登入到RealServer 方法一免密登录 现计划尝试方法二 只有1个tom 我连了两个tom 看来是根据IP划…...

批量重命名bat

作为一名程序员&#xff0c;怎么可以自己一个个改文件名呢&#xff01; Windows的批量重命名会自动加上括号和空格&#xff0c;看着很不爽&#xff0c;写一个bat处理吧&#xff01;❥(ゝω・✿ฺ) 功能&#xff1a;将当前目录下的所有文件名里面当括号和空格都去掉。 用法&…...

Unity动画系统使用整理 --- Playable

​​Playable API​​ 是一个强大的工具&#xff0c;用于更灵活地控制动画、音频、脚本等时间轴内容的播放和混合。它提供了比传统 Animator 更底层、更可控的方式管理时间轴行为&#xff0c;尤其适合复杂动画逻辑或动态内容组合的场景。 优点&#xff1a; 1.Playables API 支…...

用C语言实现的——一个完整的AVL树的交互式系统

一、知识要点 AVL树&#xff08;Adelson-Velsky and Landis Tree&#xff09;是一种自平衡二叉搜索树&#xff0c;由俄罗斯计算机科学家 Georgy Adelson-Velsky 和 Evgenii Landis 在 1962 年提出。它具备以下特点&#xff1a; AVL树的性质 二叉搜索树&#xff08;排序树&am…...

洛谷B3648 [语言月赛202208] 你几岁了

#include<bits/stdc.h> using namespace std; int main(){int n;cin>>n;cout<<"I am "<<n<<" years old.";return 0; }...

智能指针入门:深入理解 C++ 的 shared_ptr

文章目录 前言一、什么是 shared_ptr&#xff1f;二、创建share_ptr三、使用share_ptr1.输出结果2.结果分析 四、工作原理五、注意事项六、使用场景总结 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 在 C 的开发中&#xff0c;手动管理内存一直是一项…...

十四、继承与组合(Inheritance Composition)

十四、继承与组合&#xff08;Inheritance & Composition&#xff09; 引言 C最引人注目的特性之一是代码复用。组合&#xff1a;在新类中创建已有类的对象。继承&#xff1a;将新类作为已有类的一个类型来创建。 14.1 组合的语法 Useful.h //C14:Useful.h #ifndef US…...

自主添加删除开机启动项

背景 有些程序我们需要每次开机自启动&#xff0c;譬如自装的第三方输入法或者网络代理软件等等&#xff0c;而有些程序我们不希望它每次开机自启动&#xff0c;但是奈何这些软件安装的时候自己就给配置好了开机自启动&#xff0c;咱们不知道该去哪找。 anyway&#xff0c;问题…...

2025年第十六届蓝桥杯软件赛省赛C/C++大学A组个人解题

文章目录 题目A题目C&#xff1a;抽奖题目D&#xff1a;红黑树题目E&#xff1a;黑客题目F&#xff1a;好串的数目 https://www.dotcpp.com/oj/train/1166/ 题目A 找到第2025个素数 #include <iostream> #include <vector> using namespace std; vector<i…...

Clickhouse 迁移到 Doris 的最佳实践

一、引言 在将数据从 Clickhouse 迁移到 Apache Doris / SelectDB Cloud 的过程中&#xff0c;涉及表结构迁移、查询语句迁移以及数据迁移等多个关键环节。每个环节都有其复杂性和需要注意的细节&#xff0c;本文将详细介绍这些内容及对应的最佳实践方法。 二、表结构迁移 &…...

thinkphp模板文件缺失没有报错/thinkphp无法正常访问控制器

省流&#xff1a;没有出现下图的报错可能是空路由规则的问题。 编者在编写一个新的控制器时还未建立模板文件&#xff0c;理应出现如下报错 但是浏览器非但没有报错&#xff0c;反而无法正常访问所有有问题的控制器&#xff0c;表现为都为空白页面&#xff0c;正常的控制器可…...

Spring AI 与 Hugging Face 深度集成:打造高效文本生成应用

Spring AI 与 Hugging Face 深度集成&#xff1a;打造高效文本生成应用 前言 在人工智能技术蓬勃发展的时代&#xff0c;大型语言模型&#xff08;LLM&#xff09;在自然语言处理领域展现出了强大的能力。Hugging Face 作为人工智能社区的重要一员&#xff0c;提供了丰富的模…...

异步FIFO的学习

一、参考视频 FPGA&#xff08;异步FIFO原理及Verilog代码实现&#xff09;_哔哩哔哩_bilibili 二、设计图 高位套圈时&#xff0c;格雷码和二进制不一样的地方 需要注意的问题 为什么二进制的变化位数更多&#xff0c;就更容易产生亚稳态呢&#xff1f; 格雷码 格雷码&…...

Java——API基础(String类和StringBuilder类)

一、API概述 API&#xff1a;应用程序编程接口&#xff08;是一些包含了属性和方法的类&#xff09; Java API&#xff1a;指的就是JDK中提供各种功能的Java类 二、String类&#xff08;在lang包下&#xff0c;不需要导包&#xff09; &#xff08;一&#xff09;概述 1.J…...

OpenCV图像金字塔详解:原理、实现与应用

一、什么是图像金字塔&#xff1f; 图像金字塔是图像处理中一种重要的多尺度表示方法&#xff0c;它通过对图像进行重复的平滑和降采样&#xff08;或上采样&#xff09;操作&#xff0c;生成一系列分辨率逐渐降低&#xff08;或升高&#xff09;的图像集合。这种结构形似金字…...

AI Agent(11):垂直行业应用

引言 本文将聚焦AI Agent在金融、医疗健康、制造业以及零售与电商四个重要垂直行业的应用。我们将分析每个行业的特定需求和挑战,探讨AI Agent如何通过专业化能力为这些行业创造价值,并展望未来发展趋势。 垂直行业AI Agent的核心价值在于将通用AI能力与行业专业知识深度结…...