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

面试官:MySQL 唯一索引和主键索引的区别?(修订版)

在线 Java 面试刷题持续更新https://www.quanxiaoha.com/java-interview面试考察点索引类型理解面试官不仅仅是想知道 有什么区别更是想考察你是否理解主键索引聚簇索引和唯一索引二级索引在存储结构上的根本差异。NULL 值处理考察你是否清楚主键不允许 NULL而唯一索引可以但只能有一个这是很多面试者容易忽略的细节。性能优化意识理解聚簇索引和非聚簇索引的查询效率差异能否在设计表结构时做出正确选择。核心答案主键索引一种特殊的唯一索引每张表只能有一个用于唯一标识每一行记录InnoDB 中主键是聚簇索引。唯一索引保证索引列的值唯一一张表可以有多个唯一索引InnoDB 中唯一索引是二级索引非聚簇索引。核心区别对比对比维度主键索引PRIMARY唯一索引UNIQUE数量限制每表只能有 1 个每表可以有多个NULL 值不允许NULL允许NULL但最多 1 个存储结构聚簇索引叶子节点存完整数据二级索引叶子节点存主键值索引回表不需要回表需要回表查询非索引列时创建语法PRIMARY KEY (col)UNIQUE KEY uk_name (col)是否必须建议有但不强制按需创建一句话总结主键是唯一的聚簇索引不允许 NULL唯一索引是可以有多个的非聚簇索引允许 NULL。深度解析一、存储结构差异聚簇索引 vs 二级索引主键索引和唯一索引在 InnoDB 中的存储结构完全不同img上图对比了主键索引和唯一索引的存储结构。关键区别在于主键索引聚簇索引叶子节点直接存储完整的行数据通过主键查询可以直接获取所有字段无需回表唯一索引二级索引叶子节点只存储索引列的值 主键值如果查询其他字段需要拿着主键值回表查询聚簇索引二、NULL 值处理差异这是面试中的高频考点-- 创建测试表 CREATETABLEuser ( idBIGINT PRIMARY KEY, -- 主键不允许 NULL email VARCHAR(50) UNIQUE, -- 唯一索引允许 NULL phone VARCHAR(20) UNIQUE -- 唯一索引允许 NULL ); -- 主键测试插入 NULL 会报错 INSERTINTOuser (id, email) VALUES (NULL, testqq.com); -- ❌ ERROR 1048: Column id cannot be null -- 唯一索引测试允许 NULL且 MySQL 中可以插入多个 NULL INSERTINTOuser (id, email) VALUES (1, NULL); -- ✅ 成功 INSERTINTOuser (id, email) VALUES (2, NULL); -- ✅ 成功MySQL 认为多个 NULL 不重复 INSERTINTOuser (id, email) VALUES (3, aqq.com); -- ✅ 成功 INSERTINTOuser (id, email) VALUES (4, aqq.com); -- ❌ Duplicate entryimg关键结论主键绝对不允许 NULL这是主键的基本约束唯一索引允许 NULL且 MySQL 中可以插入多个 NULL 值因为NULL ! NULL三、查询性能差异回表问题通过主键查询 vs 通过唯一索引查询的性能差异-- 表结构 CREATETABLEuser ( idBIGINT PRIMARY KEY, email VARCHAR(50) UNIQUE, nameVARCHAR(50), age INT ); -- 场景 1通过主键查询 SELECT * FROMuserWHEREid 1; -- ✅ 直接走聚簇索引一次查询即可获取完整数据 -- 场景 2通过唯一索引查询所有字段 SELECT * FROMuserWHERE email testqq.com; -- ⚠️ 需要回表先查唯一索引得到 id再回表查聚簇索引 -- 场景 3通过唯一索引查询索引列覆盖索引 SELECT email FROMuserWHERE email testqq.com; -- ✅ 覆盖索引不需要回表img四、使用场景建议场景推荐索引类型原因标识每一行记录主键索引每表必须有唯一标识推荐自增 BIGINT用户邮箱不能重复唯一索引业务唯一性约束允许未设置邮箱NULL手机号唯一唯一索引允许用户暂未绑定手机号身份证号唯一唯一索引允许 NULL可能未录入联合唯一用户 日期联合唯一索引UNIQUE KEY uk_user_date (user_id, date)最佳实践-- 推荐使用 BIGINT 自增主键 CREATETABLE orders ( idBIGINTUNSIGNED AUTO_INCREMENT PRIMARY KEY, order_no VARCHAR(32) UNIQUENOTNULL, -- 业务订单号不允许 NULL user_id BIGINTNOTNULL, INDEX idx_user (user_id) ); -- 不推荐没有主键的表 -- MySQL 会自动选择一个非空唯一索引作为聚簇索引 -- 如果没有合适的会生成一个隐藏的 6 字节主键五、如果没有主键会怎样InnoDB 要求每张表必须有聚簇索引img面试高频追问追问一为什么推荐使用自增主键而不是 UUID答自增主键是顺序插入的B 树叶子节点顺序追加不会产生页分裂UUID 是无序的插入会导致频繁页分裂影响性能。此外UUID 占用空间大36 字符 vs 8 字节降低索引效率。追问二一张表可以没有主键吗答可以但 InnoDB 会自动选择一个非空唯一索引作为聚簇索引如果没有合适的会生成隐藏的 6 字节ROW_ID。但强烈不建议这样做应该显式定义主键。追问三联合主键和联合唯一索引有什么区别答本质区别和单列一样——联合主键是聚簇索引不允许任何列为 NULL联合唯一索引是二级索引允许列为 NULL。常见面试变体主键索引和唯一索引有什么区别聚簇索引和非聚簇索引的区别是什么MySQL 查询走唯一索引时为什么可能需要回表唯一索引允许 NULL 吗主键呢记忆口诀主键 vs 唯一索引主键聚簇叶子存完整数据查询不回表唯一二级叶子存主键值查询需回表NULL 有别主键不允许唯一索引可以数量不同主键唯一一个唯一索引多个总结主键索引是聚簇索引每表只能有一个不允许 NULL叶子节点存储完整行数据唯一索引是二级索引可以有多个允许 NULL可多个叶子节点存储主键值。查询时主键直接获取数据唯一索引需要回表。推荐使用BIGINT自增主键业务唯一约束用唯一索引。 欢迎加入小哈的星球你将获得:专属的项目实战多个项目 / 1v1 提问 /Java 学习路线 /学习打卡 / 每月赠书 / 社群讨论新项目《Spring AI 项目实战》正在更新中..., 基于 Spring AI Spring Boot 3.x JDK 21;《从零手撸仿小红书微服务架构》 已完结基于 Spring Cloud Alibaba Spring Boot 3.x JDK 17..., 点击查看项目介绍演示地址http://116.62.199.48:7070/《从零手撸前后端分离博客项目全栈开发》2期已完结,演示链接http://116.62.199.48/;专栏阅读地址https://www.quanxiaoha.com/column截止目前累计输出 100w 字讲解图 4013 张还在持续爆肝中..后续还会上新更多项目目标是将 Java 领域典型的项目都整一波如秒杀系统, 在线商城, IM 即时通讯Spring Cloud Alibaba 等等戳我加入学习解锁全部项目已有4500小伙伴加入1. 我的私密学习小圈子从0到1手撸企业实战项目~ 2. 面试官灵魂一问MySQL 深度分页如何优化修订版 3. 锁明明还没过期为什么另一个线程能抢进去 4. 阿里二面什么是 MySQL 回表查询如何避免修订版最近面试BAT整理一份面试资料《Java面试BATJ通关手册》覆盖了Java核心技术、JVM、Java并发、SSM、微服务、数据库、数据结构等等。 获取方式点“在看”关注公众号并回复 Java 领取更多内容陆续奉上。PS因公众号平台更改了推送规则如果不想错过内容记得读完点一下“在看”加个“星标”这样每次新文章推送才会第一时间出现在你的订阅列表里。 点“在看”支持小哈呀谢谢啦

相关文章:

面试官:MySQL 唯一索引和主键索引的区别?(修订版)

在线 Java 面试刷题(持续更新):https://www.quanxiaoha.com/java-interview面试考察点索引类型理解:面试官不仅仅是想知道 "有什么区别",更是想考察你是否理解主键索引(聚簇索引)和唯…...

3步实现多平台同步直播:obs-multi-rtmp高效推流指南

3步实现多平台同步直播:obs-multi-rtmp高效推流指南 【免费下载链接】obs-multi-rtmp OBS複数サイト同時配信プラグイン 项目地址: https://gitcode.com/gh_mirrors/ob/obs-multi-rtmp obs-multi-rtmp是一款专为OBS Studio设计的多平台推流插件,能…...

AI专著撰写高效之道:优质工具推荐,专著写作快又好

学术专著的主要价值在于其系统性和逻辑的完整性,但这却是写作过程中最难以攻克的难题。与专注于单一议题的期刊文章不同,AI 写专著需要构建一个包含绪论、理论基础、核心研究、应用拓展和结论的整体框架。各个章节之间要相互关联,层层递进&am…...

OnmyojiAutoScript副本效率提升指南:从异常排查到性能优化

OnmyojiAutoScript副本效率提升指南:从异常排查到性能优化 【免费下载链接】OnmyojiAutoScript Onmyoji Auto Script | 阴阳师脚本 项目地址: https://gitcode.com/gh_mirrors/on/OnmyojiAutoScript 阴阳师自动脚本(OnmyojiAutoScript)作为一款为玩家提供自动…...

突破设备壁垒:用swyh-rs构建零成本家庭音频网络的新方案

突破设备壁垒:用swyh-rs构建零成本家庭音频网络的新方案 【免费下载链接】swyh-rs Stream What You Hear written in rust, inspired by SWYH. 项目地址: https://gitcode.com/gh_mirrors/sw/swyh-rs 在智能家居普及的今天,音频设备却常常陷入&qu…...

5大核心优势揭秘:TradingAgents-CN如何用AI重构金融智能决策?

5大核心优势揭秘:TradingAgents-CN如何用AI重构金融智能决策? 【免费下载链接】TradingAgents-CN 基于多智能体LLM的中文金融交易框架 - TradingAgents中文增强版 项目地址: https://gitcode.com/GitHub_Trending/tr/TradingAgents-CN 当个人投资…...

SSA-KELM多输出回归算法的MATLAB实现与应用:基于麻雀搜索算法优化核极限学习机的代码...

SSA-KELM多输入多输出回归 基于麻雀搜索算法(SSA)优化核极限学习机(KELM)的数据多输出回归预测,Matlab代码,可直接运行,适合小白新手(多输入多输出回归预测) 程序已经调试好,仅需根据需要修改outdim值(输出个数)替换数据集即可运行…...

Step3-VL-10B-Base赋能产业分析:解读“一线产区和二线产区”视觉差异

Step3-VL-10B-Base赋能产业分析:解读“一线产区和二线产区”视觉差异 你有没有想过,那些摆在货架上、标着不同产区的商品,比如茶叶、葡萄酒,它们看起来到底有什么不一样?是包装更精美,还是颜色更深邃&…...

5大场景全面解析SWE-bench:语言模型软件工程能力实战指南

5大场景全面解析SWE-bench:语言模型软件工程能力实战指南 【免费下载链接】SWE-bench SWE-Bench: Can Language Models Resolve Real-world Github Issues? 项目地址: https://gitcode.com/GitHub_Trending/sw/SWE-bench 核心价值:为什么SWE-ben…...

电子电路耦合技术详解与应用指南

1. 电子电路中的耦合技术解析1.1 耦合的基本概念在电子电路设计中,耦合是指将前级电路(信号源)的能量传递至后级电路(负载)的技术过程。这一基础概念在各类电子系统中具有普遍应用价值,特别是在多级放大电路…...

ESP设备精准控制终极指南:esptool的量子级实时响应技术

ESP设备精准控制终极指南:esptool的量子级实时响应技术 【免费下载链接】esptool Espressif SoC serial bootloader utility 项目地址: https://gitcode.com/gh_mirrors/es/esptool esptool是一款由Espressif Systems开发的专业串行引导程序工具,…...

Windows Server 2008 R2提权实战:用MS15-051漏洞从WebShell到System权限的完整操作记录

Windows Server 2008 R2权限提升实战:从低权限到系统控制的技术剖析 在渗透测试的实战场景中,获取初始立足点往往只是开始。当安全研究人员或红队成员通过Web漏洞获得了一个低权限的WebShell后,如何突破权限限制,获取系统最高控制…...

DeepSeek-OCR-2零售行业应用:商品标签识别系统实现

DeepSeek-OCR-2零售行业应用:商品标签识别系统实现 1. 零售行业的标签识别痛点在哪里 超市货架上密密麻麻的商品,每一件都贴着标签——价格、条形码、生产日期、保质期、规格参数……这些信息看似简单,却构成了零售运营最基础也最繁琐的一环…...

扔掉特征变换和激活函数!LightGCN极简图卷积推荐模型实战(PyTorch/TensorFlow)

LightGCN:极简图卷积在推荐系统中的革命性实践 在推荐系统领域,图卷积网络(GCN)已经成为协同过滤的新宠。然而,当我们深入分析传统GCN架构时,会发现许多为图分类任务设计的复杂组件在推荐场景下反而成为性能瓶颈。LightGCN的出现&…...

HeyGem数字人视频生成系统效果实测:口型精准同步,画面自然

HeyGem数字人视频生成系统效果实测:口型精准同步,画面自然 最近我在测试各种AI视频生成工具时,发现了一个很有意思的系统——HeyGem数字人视频生成系统。这个系统最大的特点就是能把一段音频和一个带人脸的视频结合起来,生成一个…...

Laravel SEO优化终极指南:SEOTools与Sitemap、RSS等工具的完美配合

Laravel SEO优化终极指南:SEOTools与Sitemap、RSS等工具的完美配合 【免费下载链接】seotools SEO Tools for Laravel 项目地址: https://gitcode.com/gh_mirrors/se/seotools 想要让你的Laravel应用在搜索引擎中脱颖而出吗?SEO优化是每个Web开发…...

5个自动驾驶开发者必备的行人轨迹预测数据集(含ETH/UCY实测对比)

5个自动驾驶开发者必备的行人轨迹预测数据集(含ETH/UCY实测对比) 行人轨迹预测是自动驾驶系统中的关键技术之一。准确预测行人未来几秒内的移动路径,能显著提升自动驾驶车辆的安全性和舒适性。对于算法工程师而言,选择合适的数据集…...

Nanobot知识图谱:Neo4j数据库集成指南

Nanobot知识图谱:Neo4j数据库集成指南 1. 引言 想象一下,你的AI助手不仅能回答简单问题,还能理解复杂的关系网络——比如公司内部的汇报关系、产品之间的关联性,甚至是学术文献中的引用关系。这就是知识图谱的魅力所在。 在实际…...

5个Kubernetes网络策略常见误区:从Network Policy Recipes中学习正确配置

5个Kubernetes网络策略常见误区:从Network Policy Recipes中学习正确配置 【免费下载链接】kubernetes-network-policy-recipes Example recipes for Kubernetes Network Policies that you can just copy paste 项目地址: https://gitcode.com/gh_mirrors/ku/kub…...

Halcon实战:用shape_trans算子5分钟搞定不规则区域的最小外接矩形提取

Halcon实战:5分钟精准提取不规则区域最小外接矩形的工业级方案 在工业视觉检测领域,我们常常需要从复杂的背景中快速定位目标物体的精确边界。无论是印刷电路板上的字符识别、机械零件的尺寸测量,还是包装盒的位置校准,准确的目标…...

5个维度打造你的专属音乐中心:开源音乐播放器MusicFree全解析

5个维度打造你的专属音乐中心:开源音乐播放器MusicFree全解析 【免费下载链接】MusicFree 插件化、定制化、无广告的免费音乐播放器 项目地址: https://gitcode.com/GitHub_Trending/mu/MusicFree 你是否厌倦了主流音乐平台的广告轰炸和版权限制?…...

PL_microEPD嵌入式电子纸驱动库详解

1. PL_microEPD 库概述 PL_microEPD 是一个面向 Plastic Logic 公司全系列柔性电子纸显示模组(Electrophoretic Display, EPD)的通用硬件抽象库,专为嵌入式微控制器平台设计。该库核心适配基于 UC8156 显示驱动 IC 的 1.1 英寸、1.4 英寸、2.…...

从电机测试到上位机:一个硬件工程师用LabWindows/CVI搞定周立功USBCAN的踩坑实录

从电机测试到上位机:LabWindows/CVI与USBCAN实战指南 作为一名长期与电机打交道的硬件工程师,我习惯了在示波器和逻辑分析仪的波形中寻找问题,却始终对那个神秘的"上位机"世界充满敬畏。直到某次项目 deadline 前两周,当…...

3步实现专业级降噪:NoiseTorch-ng Linux音频优化深度解析

3步实现专业级降噪:NoiseTorch-ng Linux音频优化深度解析 【免费下载链接】NoiseTorch Real-time microphone noise suppression on Linux. 项目地址: https://gitcode.com/gh_mirrors/no/NoiseTorch 在远程办公和在线会议成为常态的今天,你是否经…...

解锁《英雄联盟》专业录像编辑:开源工具League Director实战指南

解锁《英雄联盟》专业录像编辑:开源工具League Director实战指南 【免费下载链接】leaguedirector League Director is a tool for staging and recording videos from League of Legends replays 项目地址: https://gitcode.com/gh_mirrors/le/leaguedirector …...

SEO_10个提升网站排名的实用SEO技巧分享(490 )

SEO: 10个提升网站排名的实用SEO技巧分享 在数字化时代,网站排名直接关系到网站的流量和用户转化率。如果你希望在百度上提升网站排名,那么你需要掌握一些实用的SEO技巧。本文将为你分享10个提升网站排名的实用SEO技巧,希望能帮助你在竞争激烈…...

定制Windows容器:本地ISO镜像的高效配置策略

定制Windows容器:本地ISO镜像的高效配置策略 【免费下载链接】windows Windows inside a Docker container. 项目地址: https://gitcode.com/GitHub_Trending/wi/windows 在企业内网环境中部署Docker容器时,网络带宽限制和安全策略常常阻碍容器通…...

Blender 3D创作套件:5大核心技术解析与完全指南

Blender 3D创作套件:5大核心技术解析与完全指南 【免费下载链接】blender Official mirror of Blender 项目地址: https://gitcode.com/gh_mirrors/bl/blender Blender作为一款免费开源的3D创作套件,为艺术家、设计师和开发者提供了从建模、动画到…...

Omnipay响应对象终极指南:轻松掌握支付结果处理的核心技巧

Omnipay响应对象终极指南:轻松掌握支付结果处理的核心技巧 【免费下载链接】omnipay A framework agnostic, multi-gateway payment processing library for PHP 5.6 项目地址: https://gitcode.com/gh_mirrors/om/omnipay Omnipay是一个PHP支付处理库&#…...

Claude官网技术深度拆解:宪法AI与可控生成的技术哲学

在2026年的大模型阵营中,Anthropic的Claude系列以其独特的“宪法AI”理念和稳健的工程实现,走出了一条与OpenAI、Google截然不同的技术路径。当GPT追求“全能”、Gemini强调“多模态融合”、Grok偏向“风格化表达”时,Claude始终将安全可控、…...