高级java每日一道面试题-2025年01月23日-数据库篇-主键与索引有什么区别 ?

如果有遗漏,评论区告诉我进行补充

面试官: 主键与索引有什么区别 ?

我回答:

一、主键(Primary Key)

1. 定义
  • 主键是关系型数据库中的一条记录中的某个属性组(可以是一个字段或多个字段的组合),用于唯一标识一条记录。
2. 特性
  • 唯一性:主键的值必须是唯一的,不允许有重复。
  • 非空性:主键字段的值不允许为空(NULL)。
  • 约束性:主键是一种约束,用于保证数据的完整性和唯一性。
3. 作用
  • 确保数据的唯一性和完整性:通过强制每行记录的唯一性,防止重复数据,维护表的数据质量。
  • 作为表与表之间关系的参考点:主键通常用于建立表之间的外键关联,以实现一对多或多对多的关系,从而支持复杂的数据模型。
4. 性能影响
  • 自动创建唯一索引:当定义主键时,数据库系统会自动为该列创建一个唯一索引,这有助于加快基于主键的查询速度。
  • 插入/更新成本:由于主键强制唯一性检查,因此插入新记录或更新现有记录时可能会有额外的开销。

二、索引(Index)

1. 定义
  • 索引是数据库中的一种数据结构,用于存储表中特定列的值,并对这些值进行排序,以加快数据的检索速度。
2. 特性
  • 加速检索:索引通过缩小需要扫描的记录数目来加快搜索速度。
  • 可选唯一性:索引列可以有重复值(除非创建的是唯一索引),但也可以创建唯一索引来保证列值的唯一性。
  • 可选空值:索引列可以包含空值(NULL),但具体是否允许取决于索引的类型和数据库的实现。
3. 作用
  • 提高查询速度:通过索引,可以大大加快数据的检索速度,避免进行全表扫描。
  • 优化排序和分组:索引还可以加速表和表之间的连接,特别是在实现数据的参考完整性方面特别有意义。此外,在使用分组(GROUP BY)和排序(ORDER BY)子句进行数据检索时,索引同样可以显著减少查询中分组和排序的时间。
4. 性能影响
  • 正向影响
    • 加快查询速度,特别是当查询条件中包含索引列时。
    • 减少磁盘 I/O 和内存使用,因为不需要扫描整个表。
  • 负向影响
    • 插入、更新和删除操作的成本增加,因为每次修改数据后都需要更新索引。
    • 占用额外的存储空间,尤其是大型表和复杂索引结构。

三、主键与索引的区别

特性主键(Primary Key)索引(Index)
定义用于唯一标识表中每一行记录一种数据结构,用于加速查询和检索操作
数量限制每个表只能有一个主键可以创建多个不同类型的索引
唯一性必须唯一根据索引类型决定(唯一索引要求唯一)
空值不允许 NULL允许 NULL(除了唯一索引)
默认行为自动创建唯一索引需要显式创建
主要用途维护数据完整性,建立表间关系提高查询性能,优化特定查询模式
性能影响插入/更新时有额外开销插入/更新/删除时有额外开销,查询时性能提升

四、总结

主键和索引虽然都与数据的唯一性和检索效率有关,但它们有不同的侧重点和应用场景:

  • 主键主要用于保证数据的唯一性和完整性,并作为表间关联的基础。它具有唯一性和非空性的严格要求,并且默认会创建唯一索引。
  • 索引则是为了提高查询速度而设计的数据结构,可以根据需求创建多种类型的索引,适用于不同的查询场景。索引可以显著改善读取性能,但也可能增加写入操作的开销。

理解这些差异不仅有助于更好地设计数据库模式,还能在面试中展示你对数据库优化和技术细节的深刻理解。通过合理运用主键和索引,可以在保证数据质量的同时,最大限度地发挥数据库的性能优势。

五、应用建议

  • 选择合适的主键:根据业务逻辑选择最能唯一标识记录的字段作为主键,尽量使用自增整数或全局唯一标识符(如 UUID)。
  • 谨慎创建索引:并非所有列都需要创建索引,应该基于实际查询模式和性能需求来创建索引,以避免不必要的性能损失。
  • 定期评估索引的有效性:随着数据的增长和查询模式的变化,原有的索引可能不再适用,应定期审查和调整索引策略。
  • 利用复合索引:对于涉及多个字段的查询,可以考虑创建复合索引,以进一步优化查询性能。

通过以上方法,可以有效地管理和优化数据库中的主键和索引,从而提高系统的整体性能和可靠性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/7923.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【测试】UI自动化测试

长期更新,建议关注收藏点赞! 目录 概论WEB环境搭建Selenium元素定位 APPAppium 概论 user interface UI 使用工具和代码执行用例。 什么样的项目需要自动化? 需要回归测试、自动化的功能模块需求变更不频繁、项目周期长(功能测试…

【随手笔记】FFT资料整理

&#xff08;一&#xff09;结果验证 函数波形示例1 #define Fs 44800 #define NPT 256 void InitBufInArray() {int i 0;float fx 0;for(i0; i<NPT; i){// fx 1500 * sin(2*PI * i * 350.0 / Fs) // 2700 * sin(2*PI * i * 8400.0 / Fs) // 4000 * sin(2*P…

Airflow:Airflow子流程应用实践

Apache Airflow是一个强大的开源平台&#xff0c;用于以编程方式编写、调度和监控工作流。它的一个强大功能是使用子DAG&#xff08;子有向无环图&#xff09;创建复杂工作流的能力&#xff0c;子DAG本质上是在父DAG中更小的嵌套DAG。在这篇博文中&#xff0c;我们将深入探讨su…

狗狗能吃萝卜吗?

各位铲屎官们&#xff0c;今天咱们来聊聊一个超实用的话题&#xff1a;狗狗能吃萝卜吗&#xff1f;很多新手铲屎官可能会觉得萝卜营养丰富&#xff0c;想给狗狗也尝尝鲜&#xff0c;但其实这里面大有讲究&#xff01; 狗狗可以吃萝卜&#xff0c;但要注意方法 首先&#xff0c…

Excel制作合同到期自动提醒!

大家好&#xff0c;我是小鱼。 今天分享一下如何利用Excel制作合同到期提醒表&#xff0c;实现Excel表格自动计算合同到期日和天数&#xff0c;根据合同状态和到期天数自动填充颜色提醒&#xff0c;超实用。先看一下效果&#xff0c;已经到期的合同会自动被填充为红色&#xf…

Python Flask教程

一、前言 Flask是一个用Python编写的轻量级的Web应用框架。 Flask基于WSGI&#xff08;Web Server Gateway Interface&#xff09;和 Jinja2 模板引擎&#xff0c;旨在帮助开发者快速、简便地创建 Web 应用。 Flask 被称为"微框架"&#xff0c;因为它使用简单的核…

【Numpy核心编程攻略:Python数据处理、分析详解与科学计算】1.10 文本数据炼金术:从CSV到结构化数组

1.10 《文本数据炼金术&#xff1a;从CSV到结构化数组》 目录 #mermaid-svg-TNkACjzvaSXnULaB {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-TNkACjzvaSXnULaB .error-icon{fill:#552222;}#mermaid-svg-TNkACjzva…

Linux进程概念:【环境变量】【程序地址空间】

目录 一.环境变量 1.1基本概念 1.2命令行参数 1.3一个例子&#xff0c;一个环境变量 1.4环境变量的组织方式 1.5查看环境变量的方法 ​编辑 1.6从存储的角度理解环境变量 1.7环境变量最开始是从系统的配置文件里来的 1.8认识更多的环境变量 HOME HISTSIZE HOSTNANE…

医疗集群系统中基于超融合数据库架构的应用与前景探析

一、引言 1.1 研究背景与意义 随着医疗信息化的飞速发展,医疗数据呈爆炸式增长。从日常诊疗记录、患者病历,到各类医疗影像、检查检验数据等,海量信息不断涌现。据统计,医疗数据的年增长率高达 30% 以上 ,2025 年,全球医疗数据量将达到 2314 艾字节(EB)。如此庞大的数…

【leetcode100】从前序与中序遍历序列构造二叉树

1、题目描述 给定两个整数数组 preorder 和 inorder &#xff0c;其中 preorder 是二叉树的先序遍历&#xff0c; inorder 是同一棵树的中序遍历&#xff0c;请构造二叉树并返回其根节点。 示例 1: 输入: preorder [3,9,20,15,7], inorder [9,3,15,20,7] 输出: [3,9,20,nul…

【CSS入门学习】Flex布局设置div水平、垂直分布与居中

水平平均分布 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title><style>…

【ARM】解决MDK在打开工程的时候提示CMSIS的版本不对问题

1、 文档目标 解决MDK在打开使用Compiler 6的工程的时候&#xff0c;提示CMSIS 的API版本过低的报错。 2、 问题场景 客户在Pack包中打开一个示例工程&#xff0c;打算熟悉一下对应芯片的功能和软件的功能&#xff0c;但是&#xff0c;打开软件后&#xff0c;在构建信息输出框…

PyCharm接入DeepSeek实现AI编程

目录 效果演示 创建API key 在PyCharm中下载CodeGPT插件 配置Continue DeepSeek 是一家专注于人工智能技术研发的公司&#xff0c;致力于开发高性能、低成本的 AI 模型。DeepSeek-V3 是 DeepSeek 公司推出的最新一代 AI 模型。其前身是 DeepSeek-V2.5&#xff0c;经过持续的…

【PyTorch][chapter 29][李宏毅深度学习]Fine-tuning LLM

参考&#xff1a; https://www.youtube.com/watch?veC6Hd1hFvos 目录&#xff1a; 什么是 Fine-tune 为什么需要Fine-tuning 如何进行Fine-tune Fine-tuning- Supervised Fine-tuning 流程 Fine-tuning参数训练的常用方案 LORA 简介 示例代码 一 什么是 Fine-tune …

动手学图神经网络(3):利用图神经网络进行节点分类 从理论到实践

利用图神经网络进行节点分类&#xff1a;从理论到实践 前言 在之前的学习中&#xff0c;大家对图神经网络有了初步的了解。本次教程将深入探讨如何运用图神经网络&#xff08;GNNs&#xff09;来解决节点分类问题。在节点分类任务里&#xff0c;大家往往仅掌握少量节点的真实…

云原生:构建现代化应用的基石

一、什么是云原生&#xff1f; 云原生是一种构建和运行应用程序的方法&#xff0c;旨在充分利用云计算的分布式系统优势&#xff0c;例如弹性伸缩、微服务架构、容器化技术等。云原生应用程序从设计之初就考虑到了云环境的特点&#xff0c;能够更好地适应云平台的动态变化&…

springboot3 集成 knife4j(接口文档)

提示&#xff1a;文章是集成 knife4j&#xff0c;而非 swagger2 或者 swagger3&#xff0c;效果如图 文章目录 前言一、添加依赖二、如何集成1.配置文件2.注解部分1.Tag2.Operation3.Parameter4.Schema 3.使用 总结 前言 提示&#xff1a;&#xff1a;大家在开发阶段&#xff…

基于单片机的智能小区门禁系统设计(论文+源码)

1总体架构 智能小区门禁系统以STM32单片机和WiFi技术为核心&#xff0c;STM32单片机作为主控单元&#xff0c;通过WiFi模块实现与手机APP的连接&#xff0c;构建整个门禁系统。系统硬件包括RFID模块、指纹识别模块、显示屏、按键以及继电器。通过RFID绑定IC卡、APP面部识别、指…

后盾人JS--闭包明明白白

延伸函数环境生命周期 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title> <…

The just sharing principle: advice for advice givers

原文 A while ago I wrote about how Only you know what’s best for your application. That’s because only you fully understand the context within which you are making technical decisions. Any advice need to filtered through that context in order to determi…