mysql 问题解答 2

3 存储

3.1 存储引擎

3、InnoDB 的四大特性?

InnoDB 是 MySQL 数据库中最常用的存储引擎之一,它的四大特性通常指的是:

  1. ACID 兼容性:

    • 原子性 (Atomicity): 保证事务内的操作要么全部成功,要么全部失败,不会出现中间状态。例如,银行转账操作,从一个账户向另一个账户转钱,这两个操作要么同时成功,要么同时失败。
    • 一致性 (Consistency): 确保数据库从一个一致的状态转换到另一个一致的状态。例如,数据库中有一个规则是所有的账户余额都不得为负,在进行任何事务之后,这个规则都必须被遵守。
    • 隔离性 (Isolation): 事务的隔离性指多个事务并发执行时,一个事务的操作不会影响其他事务。例如,当两个银行存款事务并行执行时,每个事务都应该看不到对方的中间状态。
    • 持久性 (Durability): 一旦事务提交,则其所做的更改将永久保存在数据库中,即使发生系统故障也不会丢失。例如,即使在事务写入数据后数据库立即崩溃,重新启动后,那些更改仍然存在。
  2. 支持事务:

    • InnoDB 提供了完整的事务支持,遵循上述 ACID 原则。例如,你可以在一个事务中执行多个更新操作,并且可以选择提交(commit)这个事务使所有更改生效,或者回滚(rollback)事务以撤销所有更改。
  3. 行级锁定和外键约束:

    • 行级锁定: InnoDB 支持行级锁定,这意味着在执行读写操作时,它锁定的是数据行而不是整个数据表。这种细粒度的锁定机制可以大幅度提升并发处理能力。例如,在处理一个订单表时,同时有多个用户操作不同的订单,行级锁定可以使他们互不干扰。
    • 外键约束: InnoDB 支持外键,确保了数据的完整性。例如,一个订单详情表可以通过外键约束关联到订单表,以确保每个订单详情都对应一个有效的订单。
  4. 崩溃恢复能力:

    • InnoDB 通过日志文件(如重做日志,即 redo log)来保证在崩溃后能够恢复数据。当系统崩溃时,InnoDB 可以利用这些日志来重建它在崩溃前的状态,确保数据不会丢失。

InnoDB 的这些特性使它成为了处理大量数据和高并发事务的首选存储引擎。

4、InnoDB 为何推荐使用自增主键?

自增主键是一种特殊的数据库表列,用于在新行插入表时自动产生一个唯一的标识符。自增字段通常是整数类型,每当新记录被插入时,这个数值会自动递增。

举例说明

假设有一个学生信息表 students,包含以下字段:student_id(学生ID)、name(姓名)和 age(年龄)。如果将 student_id 设为自增主键,那么每当新学生信息被插入到表中时,student_id 会自动设置为上一个 student_id 值加1。

CREATE TABLE students (student_id INT AUTO_INCREMENT PRIMARY KEY,name VARCHAR(100),age INT
);

插入新的学生信息时无需指定 student_id

INSERT INTO students (name, age) VALUES ('Alice', 20);
INSERT INTO students (name, age) VALUES ('Bob', 22);

在这两条记录插入后,数据库会自动为 Alice 分配 student_id 1,为 Bob 分配 student_id 2。

InnoDB 推荐使用自增主键的原因

InnoDB 存储引擎在处理数据时有其特定的方式,推荐使用自增主键的原因包括:

  1. 插入性能:

    • 当新行插入时,自增主键确保了新的值是当前最大值加一,这意味着新记录总是添加到索引的末尾。这样,InnoDB 就可以避免大量的页面分裂操作,因为不需要在索引中频繁地为新行寻找位置。
  2. B-Tree 索引结构:

    • InnoDB 使用 B-Tree 数据结构来存储索引。如果主键是随机分配的,插入新的记录可能会导致 B-Tree 的重新平衡,影响性能。自增主键保证了索引的顺序增长,减少了这种重建和维护的需要。
  3. 减少页分裂和碎片:

    • 使用自增主键可以减少数据库索引页的分裂,因为新记录总是在最后添加,这有助于减少空间和性能上的碎片化。
  4. 聚簇索引:

    • InnoDB 的表是基于主键顺序存储的,也称为聚簇索引。这意味着表数据实际上存储在主键索引的叶子节点上。拥有自增主键可以使得行数据物理上的存储是有序的,这样对主键的顺序访问会非常高效。
  5. 辅助索引效率:

    • 在 InnoDB 中,所有的非主键索引(也称为辅助索引)都包含了对应行的主键列。如果主键列是自增的,那么辅助索引就可以更快地定位到对应的行。

由于这些原因,特别是在高并发写入的场景下,InnoDB 存储引擎推荐使用自增主键以提高效率和性能。然而,也有特殊情况,例如分布式系统可能需要使用UU

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

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

相关文章

前端uniapp提交表单调用接口方法最新

目录 源码1源码2最后 源码1 <template><view class"my-add-bank-card"><!-- name"bank_name" form表单提交的input里面一定要加name绑定要传的参数 name"bank_name" type"text" v-model"address.bank_name"…

flink的起源、概念、特点、应用

flink的起源 Flink的起源可以追溯到2010年&#xff0c;当时它作为一个研究项目开始。该项目最初由德国柏林工业大学&#xff08;Berlin Institute of Technology&#xff09;的一群研究人员发起&#xff0c;包括Matei Zaharia、Kostas Tzoumas和Stephan Ewen等。 项目最初被称为…

【系统集成项目管理工程师】——6.习题一

1.&#xff08;&#xff09; 通过独立的、对网络行为和主机操作提供全面与忠实的记录&#xff0c;方便用户分析与审查事故原因&#xff0c;很像飞机上的黑匣子 A、防火墙&#xff1b;B、扫描器&#xff1b;C、防毒软件&#xff1b;D、安全审计系统 答案&#xff1a;D 2.《GB/…

【数据结构】排序算法复杂度 及 稳定性分析 【图文详解】

排序算法总结 前言[ 一 ] 小数据基本排序算法&#xff08;1&#xff09;冒泡排序&#xff08;2&#xff09;直接插入排序 [ 二 ] &#xff08;由基本排序衍生的用作&#xff09;处理大数据处理排序&#xff08;1&#xff09;堆排序&#xff08;2&#xff09;希尔排序 [ 三 ] 大…

unity中移动方案--物理渲染分层

一、三种基本移动方案 unity中的移动分为Transform和Rigidbody以及CharacterController&#xff0c;其中CharacterController功能完善&#xff0c;已经可以避免了穿墙&#xff0c;并实现了贴墙走等情况&#xff0c;需要结合性能考虑选择不同的方式。 1.使用transform,直接修改…

鳄鱼指标的3颜色线都代表什么?澳福官网一段话明白了

投资者一直在使用鳄鱼指标进行交易&#xff0c;但是对指标上面的3种颜色的K线都代表什么不明白&#xff1f;直到看到澳福官网一段话才明白&#xff0c;原来这么简单&#xff01; 鳄鱼指标&#xff0c;这一工具是由三条移动平均线组合而成。具体来说&#xff0c;蓝线&#xff0…

mybatis动态表名

1.基于mybatis官方文档 Configuration public class MybatisPlusConfig {Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor new MybatisPlusInterceptor();DynamicTableNameInnerInterceptor dynamicTableNameInnerIntercep…

(算法题)最多约数问题

最多约数问题 正整数x的约数是能整除x的正整数。正整数x 的约数个数记为div(x)。例如&#xff0c;1&#xff0c;2&#xff0c;5&#xff0c;10 都是正整数10 的约数&#xff0c;且div(10)4。设a 和b 是2 个正整数&#xff0c;a≤b&#xff0c;找出a和b之间约数个数最多的数x及其…

Spring Boot 3系列之-启动类详解

Spring Boot是一个功能强大、灵活且易于使用的框架&#xff0c;它极大地简化了Spring应用程序的开发和部署流程&#xff0c;使得开发人员能够更专注于业务逻辑的实现。在我们的Spring Boot 3系列之一&#xff08;初始化项目&#xff09;文章中&#xff0c;我们使用了Spring官方…

高效开发之:封装抛异常工具类

一、首先自定义个错误码枚举类 public enum ErrorCode {SUCCESS(0, "ok"),PARAMS_ERROR(40000, "请求参数错误"),NOT_LOGIN_ERROR(40100, "未登录"),NO_AUTH_ERROR(40101, "无权限"),NOT_FOUND_ERROR(40400, "请求数据不存在&qu…

MVC、MVP、MVI、MVVM、MVVM-C和VIPER等

以下是最重要的架构模式列表&#xff1a; 1、MVC(Model-View-Controller)&#xff1a; 它是最早被采用的设计模式之一。其主要目标是将应用程序的数据、用户界面和控制逻辑分离成三个相互关联的组件。 在这里&#xff0c;模型Model管理数据和逻辑&#xff0c;视图View显示信息…

桶装水订水系统水厂送水小程序开发;

桶装水小程序正式上线&#xff0c;支持多种商品展示形式&#xff0c;会员卡、积分、分销等功能&#xff1b; 开发订水送水小程序系统&#xff0c;基于用户、员工、商品、订单、配送站和售后管理模块&#xff0c;对每个模块进行统计分析&#xff0c;简化了分配过程&#xff0c;提…

C语言-------------#与##运算符使用分析

#运算符 1、#运算符用于在预编译期将宏参数转换为字符串 #include <stdio.h>#define message(X) #X#define CALL(f,p) (printf("This is fuction %s\n",#f),f(p))int square (int n) {return n*n; }int main() {printf("%s\r\n",message(hello…

【教3妹学编程-算法题】最大单词长度乘积

3妹&#xff1a;哇&#xff0c;今天好冷啊&#xff0c; 不想上班。 2哥&#xff1a;今天气温比昨天低8度&#xff0c;3妹要空厚一点啊。 3妹 : 嗯&#xff0c; 赶紧把我的羽绒服找出来穿上&#xff01; 2哥&#xff1a;哈哈&#xff0c;那倒还不至于&#xff0c; 不过气温骤降&…

【简朴PlainApp】通过浏览器就能管理手机文件的开源利器

简朴PlainApp 简朴是一个开源应用&#xff0c;允许您通过网络浏览器管理您的手机。您可以通过安全、易于使用的网络界面从桌面访问文件、视频、音乐、联系人、短信、通话记录等等&#xff01; 这对于手机上文件较多的朋友来说&#xff0c;从任意电脑上管理手机文件的需求还是挺…

详解IPD需求分析工具$APPEALS

够让企业生存下去的是客户&#xff0c;所以&#xff0c;众多企业提出要“以客户为中心”&#xff0c;那如何做到以客户为中心&#xff1f;IPD中给出的答案是需求管理。 需求管理流程&#xff0c;是IPD&#xff08;集成管理开发&#xff09;体系中的四大支撑流程之一&#xff0…

【源码解析】Spring Bean定义常见错误

案例1 隐式扫描不到Bean的定义 RestController public class HelloWorldController {RequestMapping(path "/hiii",method RequestMethod.GET)public String hi() {return "hi hellowrd";}}SpringBootApplication RestController public class Applicati…

android 升级后包依赖更新

1、将Android Studio 升级到3.4&#xff08;3.2以上即可&#xff09;&#xff0c;并且将gradle升级到3.4.1&#xff08;3.2.0以上即可&#xff09;&#xff0c;设置targetSdkVersion 28&#xff0c;Project的build.gradle中classpath ‘com.android.tools.build:gradle:3.4.1’…

基于AOSP源码Android-10.0.0_r41分支编译,framework开发,修改系统默认字体大小

文章目录 基于AOSP源码Android-10.0.0_r41分支编译&#xff0c;framework开发&#xff0c;修改系统默认字体大小 基于AOSP源码Android-10.0.0_r41分支编译&#xff0c;framework开发&#xff0c;修改系统默认字体大小 主要修改一个地方就行 代码源码路径 frameworks/base/co…

python df.apply()函数

DataFrame.apply(func, axis0, rawFalse, result_typeNone, args(), by_row‘compat’, kwargs) 沿df的轴应用函数 func:对每行或者每列应用的函数axis{0 or ‘index’, 1 or ‘columns’}, default 0 0是列&#xff0c;1是行 rawbool, default False result_type**{‘expand…