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

MySQL1.0

1.数据库的三大范式

范式是为了使数据库设计更加合理,规范,减少数据冗余和数据不一致等问题指定的一系列规则。

  • 第一范式:第一范式要求数据表中的每一列都是不可分割的原子数据项。例如:有一个学生信息表,包含 “学生姓名” 和 “联系方式” 两列。如果 “联系方式” 这一列中既包含手机号码又包含电子邮箱地址,那么这个表就不符合第一范式。
  • 第二范式:如果关系模式R属于第一范式,且非主键列完全依赖于主键,而不是依赖于主键的一部分,则称R属于第二范式。
  • 第三范式:在第二范式的基础上,非主键列只依赖于主键,不依赖于其他非主键

2.MySQL的binlog有几种录入格式,分别有什么区别?

  • statement格式(基于SQL语句的复制):binlog 会记录每一条修改数据的 SQL 语句。但是可能出现主从数据不一致的情况
  • row格式(基于行的复制):这种格式会记录每一行数据的实际修改情况。例如,当执行UPDATE users SET age = age + 1 WHERE id = 1;时,binlog 会记录修改前用户id = 1这一行的所有数据,以及修改后的所有数据。
  • mixed格式(混合模式复制):是两种模式的混合,MySQL会根据具体的操作自动选择合适的记录方式。

3. MySQL存储引擎MyISAM与InnoDB区别?

MyISAMInnoDB
事务不支持事务   支持事务
存储结构MyISAM在磁盘上存储成三个文件,文件名和表明相同,分别为.frm(存储表定义).MYD(存储数据).MYI(存储索引)InnoDB 存储引擎的数据文件和事务日志文件存储在磁盘上。
并发控制                只支持表级锁,意味着当一个用户对表进行写操作时,整个表都会被锁住支持行级锁和表级锁,默认使用行级锁,因为它只锁住正在操作的行                           
数据恢复方面表损坏后比较容易恢复,用check table检查表的完整性,用repair table来修复损坏的表由于支持事务和日志功能,数据恢复能力更强,可以通过事务日志来保证数据的持久性和一致性
适用场景适用于对事务要求不高,以读操作为主的应用场景适用于对事务完整性要求较高,同时有大量的插入、更新和删除操作,并且存在并发访问的应用场景

 4.MyISAM索引与InnoDB索引的区别?

索引结构差异:

  • MyISAM:使用的是非聚集索引。在这种索引结构中,索引文件和数据文件是分离的,索引叶子节点存储的是指向数据记录的指针,数据存储在独立的数据文件中。
  • InnoDB:默认采用聚集索引,数据按照主键的顺序存储在B+树的叶子节点上。

索引与数据存储的关系:

  • MyISAM:由于索引和数据是分离的,在进行查询操作时,首先通过索引找到数据的指针,然后根据指针去数据文件中读取数据。
  • InnoDB:数据和索引紧密结合在聚集索引中。进行主键查询时,可以直接定位到数据所在的物理位置,效率很高。

二级索引差异:

  • MyISAM:二级索引叶子节点存储的是指向数据记录的指针,这个指针直接指向数据文件中的记录位置。所以在查询时,通过二级索引获取指针后,直接去数据文件读取数据。
  • InnoDB:二级索引叶子节点存储的是主键值和索引列的值。当通过二级索引查询数据时,先在二级索引中找到主键值,然后再通过主键值在聚集索引中查找完整的数据记录。

5.什么是索引?

索引是一种数据结构,用于快速查找和访问数据库表的数据。

工作原理

  • 以常见的B-树和B+树索引结构为例。当在数据库表中创建一个索引时,数据库管理系统会将表中的列值按照一定的顺序构建成树状结构。例如,对于一个存储用户信息的表,其中有 “用户 ID” 列,当在 “用户 ID” 列上创建索引后,数据库会把所有用户 ID 按照大小顺序构建成 B + 树结构。
  • B+树是一种平衡树,它的每个节点存储多个索引值和指向子节点的指针

类型

  • 主键索引:是一种特殊的索引,用于唯一标识表中的每一行数据。在关系型数据库中,每个表通常都有一个主键,主键索引就是基于这个主键列构建的。例如,在一个订单表中,订单 ID 是主键,主键索引可以确保每个订单 ID 都是唯一的,并且可以通过订单 ID 快速定位到对应的订单记录。
  • 唯一索引:和主键索引类似,唯一索引也要求索引列的值是唯一的,但是一个表可以有多个唯一索引,而主键索引只有一个。比如,在用户表中除了用户 ID 作为主键索引外,用户的电子邮件地址可以设置为唯一索引,以确保每个用户的电子邮件地址在表中是唯一的。
  • 普通索引:没有唯一性限制,它可以基于表中的任何列创建。普通索引主要用于提高查询性能.
  • 组合索引:是基于表中的多个列创建的索引。组合索引在查询涉及多个列条件时非常有用。

作用

  • 提高查询速度。
  • 保证数据唯一性。
  • 支持数据的排序和分组,因为索引中的数据是按照一定顺序存储的,这有助于在执行排序和分组操作时提高性能。

 6.索引的设计原则

选择合适的列创建索引

  • 频繁用于查询条件的列:如果一个列经常出现在where子句中作为查询条件,那么对该列创建索引可以显著提高查询效率。
  • 用于连接操作的列:在多表连接查询中,用于连接的列应该创建索引,可以加速连接操作的执行。
  • 用于排序和分组的列。

避免过度索引

  • 考虑索引维护成本:索引虽然能提高查询速度,但在数据插入,更新,删除操作时,数据库需要同时维护索引结构。每次数据变动可能导致索引的重新调整,这会增加额外的开销。
  • 权衡查询和维护的频率:如果在业务中,查询操作占主导地位,适当多创建一些索引可能是有益的。

使用组合索引的原则

  • 遵循最左前缀原则。
  • 选择合适的列顺序:在组合索引中,把选择性高的列放在前面。

考虑索引列的数据类型和长度

  • 数据类型的一致性:在连接操作中,用于连接的列数据类型应该保持一致。
  • 长度的适当性:对于字符类型的列创建索引,要考虑列的长度。

相关文章:

MySQL1.0

1.数据库的三大范式 范式是为了使数据库设计更加合理,规范,减少数据冗余和数据不一致等问题指定的一系列规则。 第一范式:第一范式要求数据表中的每一列都是不可分割的原子数据项。例如:有一个学生信息表,包含 “学生…...

IDEA使用HotSwapHelper进行热部署

目录 前言JDK1.8特殊准备DECVM安装插件安装与配置参考文档相关下载 前言 碰到了一个项目,用jrebel启动项目时一直报错,不用jrebel时又没问题,找不到原因,又不想放弃热部署功能 因此思考能否通过其他方式进行热部署,找…...

简单web项目自定义部署Dockerfile

本意就是弄清楚如何做web自定义项目的镜像。 基础镜像是java:8u261-jdk,其中java路径为/opt/java webdemo1.0.0.1-SNAPSHOT.jar文件里面已经包含了lib文件。 可以设置PATH也可以不设置,但是建议设置JAVA_HOME FROM swr.cn-north-4.myhuaweicloud.com…...

基础Web安全|SQL注入

基础Web安全 URI Uniform Resource Identifier,统一资源标识符,用来唯一的标识一个资源。 URL Uniform Resource Locator,统一资源定位器,一种具体的URI,可以标识一个资源,并且指明了如何定位这个资源…...

SpringBoot -拦截器Interceptor、过滤器 Filter 及设置

Spring Boot拦截器&#xff08;Interceptor&#xff09;的概念 - 在Spring Boot中&#xff0c;拦截器是一种AOP的实现方式。它主要用于<font style"color:#DF2A3F;">拦截请求</font>&#xff0c;在请求处理之前和之后执行特定的代码逻辑。与过滤器不同的…...

C++小问题

怎么分辨const修饰的是谁 是限定谁不能被改变的&#xff1f; 在C中&#xff0c;const关键字的用途和位置非常关键&#xff0c;它决定了谁不能被修改。const可以修饰变量、指针、引用等不同的对象&#xff0c;并且具体的作用取决于const的修饰位置。理解const的规则能够帮助我们…...

avcodec_alloc_context3,avcodec_open2,avcodec_free_context,avcodec_close

avcodec_alloc_context3 是创建编解码器上下文&#xff0c;需要使用 avcodec_free_context释放 需要使用avcodec_free_context 释放 /** * Allocate an AVCodecContext and set its fields to default values. The * resulting struct should be freed with avcodec_free_co…...

强化学习的几个主要方法(策略梯度、PPO、REINFORCE实现等)(下)

由于平台字数限制&#xff0c;上文&#xff1a;https://blog.csdn.net/ooblack/article/details/144198538 4. PPO算法 近端策略优化&#xff08;proximal policy optimization&#xff0c;PPO&#xff09;算法是OpenAI的默认强化学习算法&#xff0c;在RLHF中也用到了这个算…...

计算机网络:IP协议详细讲解

目录 前言 一、IP网段划分 二、IP报头 三、解决IP地址不足-->NAT技术 前言 在之前&#xff0c;我们学习了传输层中的TCP和UDP&#xff0c;重点是TCP协议&#xff0c;他帮我们解决具体到主机的哪个应用&#xff08;端口&#xff09;、传输的可靠&#xff08;序列号、校验和…...

2024信创数据库TOP30之华为Gauss DB

近日&#xff0c;由DBC联合CIW/CIS共同发布的“2024信创数据库TOP30”榜单正式揭晓&#xff0c;汇聚了国内顶尖的数据库企业及其产品&#xff0c;成为展示中国信创领域技术实力与发展潜力的重要平台。在这份榜单中&#xff0c;华为的GaussDB凭借其卓越的技术实力、广泛的行业应…...

在线家具商城基于 SpringBoot:设计模式与实现方法探究

第3章 系统分析 用户的需求以及与本系统相似的在市场上存在的其它系统可以作为系统分析中参考的资料&#xff0c;分析人员可以根据这些信息确定出本系统具备的功能&#xff0c;分析出本系统具备的性能等内容。 3.1可行性分析 尽管系统是根据用户的要求进行制作&#xff0c;但是…...

九、Spring Boot集成Spring Security之授权概述

文章目录 往期回顾&#xff1a;Spring Boot集成Spring Security专栏及各章节快捷入口前言一、授权概述二、用户权限三、用户授权流程三、Spring Security授权方式1、请求级别授权2、方法级别授权 往期回顾&#xff1a;Spring Boot集成Spring Security专栏及各章节快捷入口 Spr…...

python之Flask入门—路由参数

语法&#xff1a; /routerName/<string:parameter_name> 其中&#xff1a;routerName代表路由名称<>中的string是参数类型&#xff0c;parameter_name为参数名称 参数类型&#xff1a; &#xff08;1&#xff09; string 接收任何没有斜杠&#xff08;/&#x…...

txt地图格式处理

1、txt地图格式 [属性描述] 坐标系2000国家大地坐标系 几度分带3 投影类型高斯克吕格 计量单位米 带号38 精度0.001 转换参数,,,,,, [地块坐标] 5,475.888,1,测试地块1,面,J50G077061,公路用地,地下, J1,1,113.22222222222222,23.129111721551794 J2,1,113.2722314…...

《数据挖掘:概念、模型、方法与算法(第三版)》

嘿&#xff0c;数据挖掘的小伙伴们&#xff01;今天我要给你们介绍一本超级实用的书——《数据挖掘&#xff1a;概念、模型、方法与算法》第三版。这本书是数据挖掘领域的经典之作&#xff0c;由该领域的知名专家编写&#xff0c;系统性地介绍了在高维数据空间中分析和提取大量…...

GitLab CVE-2024-8114 漏洞解决方案

漏洞 ID 标题严重等级CVE ID通过 LFS 令牌提升权限高CVE-2024-8114 GitLab 升级指南GitLab 升级路径查看版本漏洞查询 漏洞解读 此漏洞允许攻击者使用受害者的个人访问令牌&#xff08;PAT&#xff09;进行权限提升。影响从 8.12 开始到 17.4.5 之前的所有版本、从 17.5 开…...

request和websocket

当然&#xff0c;可以为你详细介绍 FastAPI 中的 Request 对象。Request 对象在 FastAPI 中扮演着重要的角色&#xff0c;负责封装来自客户端的 HTTP 请求信息。了解 Request 对象的使用方法和属性&#xff0c;有助于你更高效地处理请求数据、访问请求上下文以及进行各种操作。…...

一键生成后端服务,MemFire Cloud重新定义开发效率

作为开发者&#xff0c;特别是独立开发者和小团队成员&#xff0c;大家都知道开发的最大难题之一就是搭建后端服务。要让一个应用从零开始&#xff0c;除了前端的开发工作外&#xff0c;还需要考虑数据库、接口、认证、存储等等一系列繁琐的后台工作。而MemFire Cloud这款神器&…...

短视频矩阵的营销策略:批量混剪实现高效传播

在当今的商业环境中&#xff0c;短视频营销已成为企业获得市场份额的关键策略。随着消费者注意力的分散&#xff0c;传统营销方法的效果逐渐减弱。因此&#xff0c;短视频营销的重要性不言而喻。通过短视频&#xff0c;品牌能够以更为生动和直观的方式传递信息&#xff0c;从而…...

朗迪锋亮相2024人因工程与智能系统交互国际会议

2024年11月28日至30日&#xff0c;2024人因工程与智能系统交互国际会议在深圳隆重举办。此次大会以推动我国人因工程学科发展为目标&#xff0c;致力于加强国际学术交流&#xff0c;深入探讨人工智能时代的智能系统交互&#xff0c;旨在培育新质生产力&#xff0c;助力经济社会…...

OpenLayers 可视化之热力图

注&#xff1a;当前使用的是 ol 5.3.0 版本&#xff0c;天地图使用的key请到天地图官网申请&#xff0c;并替换为自己的key 热力图&#xff08;Heatmap&#xff09;又叫热点图&#xff0c;是一种通过特殊高亮显示事物密度分布、变化趋势的数据可视化技术。采用颜色的深浅来显示…...

Flask RESTful 示例

目录 1. 环境准备2. 安装依赖3. 修改main.py4. 运行应用5. API使用示例获取所有任务获取单个任务创建新任务更新任务删除任务 中文乱码问题&#xff1a; 下面创建一个简单的Flask RESTful API示例。首先&#xff0c;我们需要创建环境&#xff0c;安装必要的依赖&#xff0c;然后…...

调用支付宝接口响应40004 SYSTEM_ERROR问题排查

在对接支付宝API的时候&#xff0c;遇到了一些问题&#xff0c;记录一下排查过程。 Body:{"datadigital_fincloud_generalsaas_face_certify_initialize_response":{"msg":"Business Failed","code":"40004","sub_msg…...

相机Camera日志实例分析之二:相机Camx【专业模式开启直方图拍照】单帧流程日志详解

【关注我&#xff0c;后续持续新增专题博文&#xff0c;谢谢&#xff01;&#xff01;&#xff01;】 上一篇我们讲了&#xff1a; 这一篇我们开始讲&#xff1a; 目录 一、场景操作步骤 二、日志基础关键字分级如下 三、场景日志如下&#xff1a; 一、场景操作步骤 操作步…...

【JVM】- 内存结构

引言 JVM&#xff1a;Java Virtual Machine 定义&#xff1a;Java虚拟机&#xff0c;Java二进制字节码的运行环境好处&#xff1a; 一次编写&#xff0c;到处运行自动内存管理&#xff0c;垃圾回收的功能数组下标越界检查&#xff08;会抛异常&#xff0c;不会覆盖到其他代码…...

JVM垃圾回收机制全解析

Java虚拟机&#xff08;JVM&#xff09;中的垃圾收集器&#xff08;Garbage Collector&#xff0c;简称GC&#xff09;是用于自动管理内存的机制。它负责识别和清除不再被程序使用的对象&#xff0c;从而释放内存空间&#xff0c;避免内存泄漏和内存溢出等问题。垃圾收集器在Ja…...

TRS收益互换:跨境资本流动的金融创新工具与系统化解决方案

一、TRS收益互换的本质与业务逻辑 &#xff08;一&#xff09;概念解析 TRS&#xff08;Total Return Swap&#xff09;收益互换是一种金融衍生工具&#xff0c;指交易双方约定在未来一定期限内&#xff0c;基于特定资产或指数的表现进行现金流交换的协议。其核心特征包括&am…...

【C++从零实现Json-Rpc框架】第六弹 —— 服务端模块划分

一、项目背景回顾 前五弹完成了Json-Rpc协议解析、请求处理、客户端调用等基础模块搭建。 本弹重点聚焦于服务端的模块划分与架构设计&#xff0c;提升代码结构的可维护性与扩展性。 二、服务端模块设计目标 高内聚低耦合&#xff1a;各模块职责清晰&#xff0c;便于独立开发…...

Map相关知识

数据结构 二叉树 二叉树&#xff0c;顾名思义&#xff0c;每个节点最多有两个“叉”&#xff0c;也就是两个子节点&#xff0c;分别是左子 节点和右子节点。不过&#xff0c;二叉树并不要求每个节点都有两个子节点&#xff0c;有的节点只 有左子节点&#xff0c;有的节点只有…...

人机融合智能 | “人智交互”跨学科新领域

本文系统地提出基于“以人为中心AI(HCAI)”理念的人-人工智能交互(人智交互)这一跨学科新领域及框架,定义人智交互领域的理念、基本理论和关键问题、方法、开发流程和参与团队等,阐述提出人智交互新领域的意义。然后,提出人智交互研究的三种新范式取向以及它们的意义。最后,总结…...