深入理解数据库索引:原理、分类与优化

目录

    • 1. 索引基础
      • 1.1 索引的工作原理
    • 2. 最左匹配原则
      • 2.1 什么是最左匹配原则?
      • 2.2 示例说明
      • 2.3 最左匹配原则的图示
    • 3. 索引分类
      • 3.1 按数据结构分类
      • 3.2 按索引列数分类
      • 3.3 按唯一性分类
      • 3.4 按存储方式分类
    • 4. 聚集索引与非聚集索引的区别
      • 4.1 聚集索引
      • 4.2 非聚集索引
      • 4.3 使用示例
    • 5. 索引覆盖
      • 5.1 什么是索引覆盖?
      • 5.2 索引覆盖的优势
      • 5.3 示例说明
      • 5.4 索引覆盖的图示
    • 6. 索引下推
      • 6.1 什么是索引下推?
      • 6.2 索引下推的优势
      • 6.3 示例说明
    • 7. 为什么选择B+树作为索引的结构
      • 7.1 B+树的特点
      • 7.2 B+树vs其他数据结构
      • 7.3 B+树在数据库中的应用
    • 8. 索引优化策略
    • 9. 索引失效的情况
      • 9.1 常见的索引失效情况
      • 9.2 索引失效的图示
      • 9.3 预防索引失效的最佳实践
    • 10. EXPLAIN 命令
    • 10.1 EXPLAIN 命令简介
    • 10.2 EXPLAIN 输出字段详解
      • 10.2.1 字段详细说明
    • 10.3 如何解读 EXPLAIN 输出
    • 10.4 EXPLAIN 使用示例
    • 10.5 优化建议

1. 索引基础

索引是数据库中用于提高查询效率的数据结构。它类似于书籍的目录,可以帮助数据库快速定位到所需的数据,而不必扫描整个表。

1.1 索引的工作原理

当我们在数据库中创建索引时,数据库会维护一个单独的数据结构,通常是B+树,用于存储索引字段的值及其对应的行指针。这样,当我们按索引字段进行查询时,数据库可以快速找到对应的数据位置,大大减少了I/O操作。

例如,假设我们有一个包含100万条记录的用户表:

CREATE TABLE users (id INT PRIMARY KEY,name VARCHAR(50),age INT,email VARCHAR(100)
);

如果我们经常按照用户名来查询用户信息,我们可以在name字段上创建索引:

CREATE INDEX idx_name ON users(name);

这样,当我们执行以下查询时:

SELECT * FROM users WHERE name = '吃个早饭';

数据库会使用索引快速定位到名为’Alice’的用户,而不是扫描整个表。

2. 最左匹配原则

最左匹配原则是复合索引的一个重要特性,它决定了索引的使用效率。

2.1 什么是最左匹配原则?

最左匹配原则指的是,对于复合索引,数据库会从左到右依次使用索引中的字段。如果查询条件中没有最左边的字段,索引可能无法被充分利用。比如创建a,b,c的联合索引,他在创建时会先对a进行排序,在a相同的一组中对b进行排序,b相同的一组中再按照c排序,因此,b只是在a值一定时才是有序的,在整体上b是无序的,c同理。图示:

数据库排序

2.2 示例说明

假设我们有一个复合索引:

CREATE INDEX idx_name_age_email ON users(name, age, email);

以下查询可以有效地使用索引:

  1. SELECT * FROM users WHERE name = 'CZF';
  2. SELECT * FROM users WHERE name = 'CZF' AND age = 20;
  3. SELECT * FROM users WHERE name = 'CZF' AND age = 20 AND email = 'CZF@example.com

但是,以下查询可能无法充分利用索引:

  1. SELECT * FROM users WHERE age = 20; (没有使用最左边的name字段)
  2. SELECT * FROM users WHERE email = 'CZF@example.com'; (没有使用最左边的name字段)
  3. SELECT * FROM users WHERE name = 'CZF' and age < 30 and email = 'CZF@example.com'; (name和age可以使用索引,但是email无法使用,因为age使用了范围查询,在范围内email是无序的)

2.3 最左匹配原则的图示

让我们用一个图表来直观地展示最左匹配原则:

索引

3. 索引分类

索引可以根据不同的标准进行分类。以下是几种常见的索引分类方式:

3.1 按数据结构分类

  1. B-Tree索引:最常见的索引类型,适用于范围查询和等值查询。
  2. 哈希索引:只适用于等值查询,查询速度很快。
  3. 全文索引:用于全文搜索。
  4. 空间索引:用于地理空间数据的索引。

3.2 按索引列数分类

  1. 单列索引:只包含一个列的索引。
  2. 复合索引:包含多个列的索引。

3.3 按唯一性分类

  1. 唯一索引:索引列的值必须唯一。
  2. 非唯一索引:索引列的值可以重复。

3.4 按存储方式分类

  1. 聚集索引:决定了表中数据的物理存储顺序。
  2. 非聚集索引:不影响表中数据的物理存储顺序。

4. 聚集索引与非聚集索引的区别

聚集索引和非聚集索引是两种重要的索引类型,它们在存储和查询数据时有着本质的区别。

4.1 聚集索引

聚集索引决定了表中数据行的物理顺序。在聚集索引中,索引的叶子节点直接包含数据行。每个表只能有一个聚集索引。

特点:

  • 数据行的物理顺序与索引的顺序相同。
  • 通常是主键索引。
  • 查找速度快,特别是范围查询。

例如,在MySQL的InnoDB存储引擎中,如果表定义了主键,InnoDB会自动使用主键作为聚集索引。

4.2 非聚集索引

非聚集索引不决定表中数据行的物理顺序。非聚集索引的叶子节点包含索引字段值和一个指向数据行的指针。

特点:

  • 索引的逻辑顺序与数据行的物理顺序无关。
  • 一个表可以有多个非聚集索引。
  • 需要额外的存储空间。

聚集和非聚集索引

4.3 使用示例

假设我们有一个订单表:

CREATE TABLE orders (order_id INT PRIMARY KEY,customer_id INT,order_date DATE,total_amount DECIMAL(10, 2)
);

在这个表中,order_id 是主键,会自动成为聚集索引。如果我们经常按照客户ID查询订单,我们可以创建一个非聚集索引:

CREATE INDEX idx_customer_id ON orders(customer_id);

现在,当我们执行以下查询时:

SELECT * FROM orders WHERE customer_id = 1001;

数据库会首先使用非聚集索引 idx_customer_id 找到所有 customer_id = 1001 的记录,然后通过这些记录中的指针找到实际的数据页。

5. 索引覆盖

索引覆盖是一种优化查询的技术,它可以大大提高查询效率。

5.1 什么是索引覆盖?

索引覆盖指的是,当查询的所有列都包含在索引中时,数据库可以直接从索引中获取数据,而不需要回表查询。

5.2 索引覆盖的优势

  1. 减少I/O操作:不需要访问表数据。
  2. 提高查询速度:直接从索引获取数据比从表中获取更快。

5.3 示例说明

继续使用之前的订单表例子:

CREATE TABLE orders (order_id INT PRIMARY KEY,customer_id INT,order_date DATE,total_amount DECIMAL(10, 2)
);CREATE INDEX idx_customer_date ON orders(customer_id, order_date);

现在,如果我们执行以下查询:

SELECT customer_id, order_date FROM orders WHERE customer_id = 1001;

这个查询可以完全由索引 idx_customer_date 覆盖,因为查询的所有列(customer_idorder_date)都包含在索引中。数据库可以直接从索引中获取数据,而不需要访问表。

如果我们执行以下查询:

SELECT customer_id,total_amount,order_date FROM orders WHERE customer_id = 1001;

那么就索引就没有覆盖,因为索引表中并没有total_amount字段,因此他会拿到对应结果集的id集合,再去聚集索引查询需要的字段

5.4 索引覆盖的图示

让我们用一个图表来展示索引覆盖的工作原理:

索引覆盖

6. 索引下推

索引下推(Index Condition Pushdown, ICP)是MySQL 5.6版本引入的一种查询优化技术。

6.1 什么是索引下推?

索引下推是指在索引遍历过程中,对索引中包含的字段先做判断,过滤掉不符合条件的记录,减少回表次数。

6.2 索引下推的优势

  1. 减少回表次数,降低I/O操作。
  2. 在存储引擎层面就过滤掉了不满足条件的记录,减轻了服务器层的压力。

6.3 示例说明

假设我们有一个用户表:

CREATE TABLE users (id INT PRIMARY KEY,name VARCHAR(50),age INT,city VARCHAR(50)
);CREATE INDEX idx_name_age ON users(name, age);

考虑以下查询:

SELECT * FROM users WHERE name LIKE 'A%' AND age > 20;

在没有索引下推的情况下,MySQL会先通过索引找到所有name以’A’开头的记录,然后回表获取完整的记录,最后再判断age > 20的条件。

而使用了索引下推后,MySQL会在索引遍历过程中就判断age > 20的条件,只有满足条件的记录才会被回表查询。

7. 为什么选择B+树作为索引的结构

B+树是最常用的索引数据结构,它有许多优点使其成为数据库索引的理想选择。

7.1 B+树的特点

  1. 多路平衡查找树:每个节点可以存储多个键值,减少树的高度。
  2. 叶子节点相连:便于范围查询。
  3. 非叶子节点只存储键值:可以存储更多索引,减少I/O次数。

7.2 B+树vs其他数据结构

  1. vs 二叉树:B+树的多路特性使其高度更低,减少了查询时的I/O次数。
  2. vs 哈希表:B+树支持范围查询和排序,哈希表只支持等值查询。
  3. vs B树:B+树的所有数据都在叶子节点,便于范围查询;非叶子节点不存储数据,可以存储更多索引。这就使得B+树的整体高度较低,从而提高IO效率

7.3 B+树在数据库中的应用

在实际的数据库系统中,B+树的节点通常对应着磁盘的页面。每个节点可能包含数百个键值,这样可以显著减少树的高度,从而减少磁盘I/O操作。

例如,假设一个B+树的阶数为1000(即每个节点可以存储1000个键值),高度为3,那么它可以索引的记录数量为:

1000 * 1000 * 1000 = 10亿条记录

而只需要3次磁盘I/O就可以查找到任意一条记录。

8. 索引优化策略

了解了索引的工作原理后,我们可以采取一些策略来优化索引的使用:

  1. 选择合适的列建立索引

    • 经常用于查询条件的列
    • 经常用于连接的列
    • 经常用于排序的列
  2. 考虑列的基数:基数高(即列中不同值的数量多)的列通常更适合建立索引。

  3. 避免过多索引:索引会占用额外的存储空间,并且会在插入、更新和删除数据时带来额外的维护成本。

  4. 利用复合索引:合理使用复合索引可以减少索引的数量,并提高查询效率。

  5. 定期维护索引:随着数据的变化,索引可能会变得碎片化,定期重建索引可以提高其效率。

  6. 使用覆盖索引:尽可能地在索引中包含所有需要的列,以减少回表操作。

  7. 注意索引列的数据类型:尽量使用较小的数据类型,这样索引占用的空间就小,查询速度就更快。

9. 索引失效的情况

尽管索引能够显著提高查询性能,但在某些情况下,即使表中已经建立了索引,数据库也可能无法使用它们。了解这些情况并知道如何解决,对于优化查询性能至关重要。

9.1 常见的索引失效情况

  1. 在索引列上使用函数或表达式

当在索引列上使用函数或进行计算时,索引通常会失效。

例如:

SELECT * FROM users WHERE YEAR(birth_date) = 1990;

即使 birth_date 列上有索引,这个查询也无法使用它。

解决方法:重写查询,避免在索引列上使用函数。

SELECT * FROM users WHERE birth_date BETWEEN '1990-01-01' AND '1990-12-31';
  1. 使用 LIKE 进行前缀模糊查询

当使用 LIKE 进行前缀模糊查询时,索引会失效。

例如:

SELECT * FROM products WHERE name LIKE '%phone%';

解决方法:如果可能,使用前缀匹配而不是包含匹配。

SELECT * FROM products WHERE name LIKE 'phone%';

对于必须使用包含匹配的情况,考虑使用全文索引。

  1. 对索引列进行隐式类型转换

当查询条件中的数据类型与索引列的数据类型不匹配时,可能发生隐式类型转换,导致索引失效。

例如,如果 user_id 是整数类型:

SELECT * FROM users WHERE user_id = '100';

解决方法:确保在查询中使用正确的数据类型。

SELECT * FROM users WHERE user_id = 100;
  1. 使用 OR 连接多个条件

当使用 OR 连接多个条件时,除非所有条件都有索引,否则可能导致索引失效。

例如:

SELECT * FROM users WHERE name = 'John' OR age = 30;

解决方法:可以使用 UNION 替代 OR,或者为所有条件创建复合索引。

SELECT * FROM users WHERE name = 'John'
UNION
SELECT * FROM users WHERE age = 30;
  1. 在复合索引中不遵循最左匹配原则

如前所述,在使用复合索引时,如果查询条件不从最左列开始,可能导致索引失效。

例如,对于索引 (name, age, city):

SELECT * FROM users WHERE age = 30 AND city = 'New York';

解决方法:调整查询以遵循最左匹配原则,或调整索引顺序以适应常见查询模式。

SELECT * FROM users WHERE name IS NOT NULL AND age = 30 AND city = 'New York';
  1. 使用 NOT 操作符

使用 NOT 操作符可能导致索引失效。

例如:

SELECT * FROM users WHERE NOT (age > 20);

解决方法:尽可能重写查询以避免使用 NOT。

SELECT * FROM users WHERE age <= 20;

9.2 索引失效的图示

让我们用一个图表来直观地展示索引失效的情况:

索引失效

9.3 预防索引失效的最佳实践

  1. 理解执行计划:使用 EXPLAIN 命令来分析查询的执行计划,了解索引是否被正确使用。
  2. 定期优化:定期检查和优化慢查询,确保索引被正确使用。
  3. 合理设计索引:根据实际查询需求设计索引,避免过多或不必要的索引。
  4. 保持索引列的简单性:避免在索引列上使用复杂的表达式或函数。
  5. 正确使用索引:了解并遵循最左匹配原则,特别是在使用复合索引时。
  6. 注意数据类型:确保查询条件中使用的数据类型与索引列的数据类型一致。
  7. 考虑查询重写:有时,通过重写查询可以更好地利用现有索引。

10. EXPLAIN 命令

10.1 EXPLAIN 命令简介

EXPLAIN 命令是 MySQL 提供的一个非常有用的工具,用于分析 SELECT 查询语句的执行计划。它可以帮助数据库管理员和开发人员理解 MySQL 如何处理查询,从而优化查询性能。

使用 EXPLAIN 的基本语法如下:

EXPLAIN SELECT * FROM users WHERE id = 1;

10.2 EXPLAIN 输出字段详解

EXPLAIN 命令的输出包含多个字段,每个字段都提供了关于查询执行计划的重要信息。以下是这些字段的详细说明:

字段名描述
id查询中每个 SELECT 的序号,有多个 SELECT 的复杂查询中很有用
select_typeSELECT 的类型
table输出结果集的表
partitions匹配的分区
type访问类型
possible_keys可能会使用的索引
key实际使用的索引
key_len使用的索引的长度
ref与索引比较的列
rows预计要检查的行数
filtered按表条件过滤的行百分比
Extra额外信息

10.2.1 字段详细说明

  1. id

    • 标识 SELECT 的序号,在复杂查询中非常有用
    • 如果 id 相同,执行顺序从上到下
    • 如果 id 不同,id 值越大优先级越高,越先执行
  2. select_type

    • SIMPLE: 简单 SELECT 查询,不包含子查询或 UNION
    • PRIMARY: 最外层的 SELECT
    • SUBQUERY: 子查询中的第一个 SELECT
    • DERIVED: 派生表的 SELECT (FROM 子句的子查询)
    • UNION: UNION 中第二个或后面的 SELECT 语句
    • UNION RESULT: UNION 的结果
  3. table

    • 显示这一行数据是关于哪张表的
  4. partitions

    • 匹配的分区,对于非分区表该值为 NULL
  5. type

    • 访问类型,按照从最优到最差的顺序排列:
      system > const > eq_ref > ref > fulltext > ref_or_null > index_merge > unique_subquery > index_subquery > range > index > ALL
  6. possible_keys

    • 显示可能应用在这张表上的索引,一个或多个
  7. key

    • 实际使用的索引,如果为 NULL,则没有使用索引
  8. key_len

    • 表示索引中使用的字节数,可以通过该列计算查询中使用的索引的长度
  9. ref

    • 显示索引的哪一列被使用了,如果可能的话,是一个常数
  10. rows

    • MySQL 认为必须检查的行数
  11. filtered

    • 表示此查询条件所过滤的数据的百分比
  12. Extra

    • 包含不适合在其他列中显示但十分重要的额外信息
    • 常见的值包括:
      • Using index: 使用覆盖索引
      • Using where: 使用 WHERE 子句来过滤结果
      • Using temporary: MySQL 需要创建一个临时表来存储结果
      • Using filesort: MySQL 需要额外的一次传递来进行排序

10.3 如何解读 EXPLAIN 输出

解读 EXPLAIN 输出时,需要注意以下几点:

  1. 检查 type 列:希望看到 const, eq_ref, ref 等高效的访问类型,而不是 range, index 或 ALL。

  2. 查看 key 列:确保查询使用了预期的索引。

  3. 检查 rows 列:这个值越小越好,表示 MySQL 需要扫描的行数较少。

  4. 注意 Extra 列:寻找可能的优化点,如 “Using temporary” 或 “Using filesort” 可能表示需要优化。

  5. 对于复杂查询,关注 idselect_type 列,了解查询的执行顺序和类型。

10.4 EXPLAIN 使用示例

让我们通过一个实际的例子来说明 EXPLAIN 的使用:

假设我们有一个 users 表和一个 orders 表,我们想要查找所有有订单的用户的信息:

EXPLAIN SELECT u.id, u.name, COUNT(o.id) as order_count
FROM users u
LEFT JOIN orders o ON u.id = o.user_id
GROUP BY u.id;

EXPLAIN 的输出可能如下:

+----+-------------+-------+------------+--------+---------------+---------+---------+--------------------+------+----------+-----------------------------------------------------+
| id | select_type | table | partitions | type   | possible_keys | key     | key_len | ref                | rows | filtered | Extra                                               |
+----+-------------+-------+------------+--------+---------------+---------+---------+--------------------+------+----------+-----------------------------------------------------+
|  1 | SIMPLE      | u     | NULL       | ALL    | PRIMARY       | NULL    | NULL    | NULL               | 1000 |   100.00 | Using temporary; Using filesort                     |
|  1 | SIMPLE      | o     | NULL       | ref    | user_id       | user_id | 4       | mydatabase.u.id    |    5 |   100.00 | Using index                                         |
+----+-------------+-------+------------+--------+---------------+---------+---------+--------------------+------+----------+-----------------------------------------------------+

解读:

  1. 查询首先扫描整个 users 表(type = ALL)。
  2. 然后对每个用户,通过索引查找对应的订单(type = ref)。
  3. 使用了临时表和文件排序来进行 GROUP BY 操作(Extra 列)。

10.5 优化建议

基于上面的 EXPLAIN 输出,我们可以考虑以下优化:

  1. users 表的 id 列上创建索引,改善对 users 表的访问类型。
  2. 考虑是否可以避免使用 GROUP BY,或者在 users 表上添加覆盖索引来消除 “Using temporary” 和 “Using filesort”。
  3. 如果 order_count 不需要非常精确,可以考虑将其预先计算并存储在 users 表中,定期更新。

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

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

相关文章

Three.js相机Camera控件知识梳理

原文&#xff1a;https://juejin.cn/post/7231089453695238204?searchId20241217193043D32C9115C2057FE3AD64 1. 相机类型 Three.js 主要提供了两种类型的相机&#xff1a;正交相机&#xff08;OrthographicCamera&#xff09;和透视相机&#xff08;PerspectiveCamera&…

一条线上的点

给你一个数组 points &#xff0c;其中 points[i] [xi, yi] 表示 X-Y 平面上的一个点。求最多有多少个点在同一条直线上。 提示&#xff1a; 1 < points.length < 300points[i].length 2-104 < xi, yi < 104points 中的所有点 互不相同 解析&#xff1a;使用斜…

XX服务器上的npm不知道咋突然坏了

收到同事的V&#xff0c;说是&#xff1a;182上的npm不知道咋突然坏了&#xff0c;查到这里了&#xff0c;不敢动了。 咱一定要抓重点&#xff1a;突然坏了。这里的突然肯定不是瞬间&#xff08;大概率是上次可用&#xff0c;这次不可用&#xff0c;中间间隔了多长时间&#x…

HALCON 算子 之 形态学操作算子

文章目录 什么是形态学操作&#xff1f;为什么要形态学操作&#xff1f;怎么形态学操作&#xff1f;腐蚀 —— Erosionerosion1erosion_circle&#xff1a;erosion_rectangle1&#xff1a; 膨胀 —— Dilationdilation1dilation_circledilation_rectangle1 打开 —— Openingop…

pytest入门九:feature

fixture是pytest特有的功能&#xff0c;用以在测试执行前和执行后进行必要的准备和清理工作。使用pytest.fixture标识&#xff0c;定义在函数前面。在你编写测试函数的时候&#xff0c;你可以将此函数名称做为传入参数&#xff0c;pytest将会以依赖注入方式&#xff0c;将该函数…

秒优科技-供应链管理系统 login/doAction SQL注入漏洞复现

0x01 产品简介 秒优科技提供的供应链管理系统,即秒优SCM服装供应链管理系统,是一款专为服装电商企业设计的全方位解决方案。是集款式研发、订单管理、物料管理、生产管理、工艺管理、收发货管理、账单管理、报表管理于一体的服装电商供应链管理解决方案。它涵盖了从企划到开…

136.WEB渗透测试-信息收集-小程序、app(7)

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 内容参考于&#xff1a; 易锦网校会员专享课 上一个内容&#xff1a;135.WEB渗透测试-信息收集-小程序、app&#xff08;6&#xff09; 进入之后我们通过输入…

K近邻原理和距离

K近邻 基本思想欧氏距离算法流程代码基于近邻用户的协同过滤基于近邻物品的协同过滤杰卡德相似度 基本思想 我们根据涂色样本点和未涂色样本点 X 的距离给涂色样本点编号1-6&#xff0c;即&#xff1a;1号样本点距离X最近&#xff0c;其余次之。 那么问题来了&#xff1a;样本…

模型 A/B测试(科学验证)

系列文章 分享 模型&#xff0c;了解更多&#x1f449; 模型_思维模型目录。控制变量法。 1 A/B测试的应用 1.1 Electronic Arts&#xff08;EA&#xff09;《模拟城市》5游戏网站A/B测试 定义目标&#xff1a; Electronic Arts&#xff08;EA&#xff09;在发布新版《模拟城…

Git merge 和 rebase的区别(附图)

在 Git 中&#xff0c;merge 和 rebase 是两种用于整合分支变化的方法。虽然它们都可以将一个分支的更改引入到另一个分支中&#xff0c;但它们的工作方式和结果是不同的。以下是对这两者的详细解释&#xff1a; Git Merge 功能&#xff1a;合并分支&#xff0c;将两个分支的…

耐蚀镍基合金的焊接技术与质量控制

耐蚀镍基合金是一类在腐蚀环境中具有优异性能的合金材料&#xff0c;广泛应用于化工、海洋工程、石油天然气等领域。其焊接技术与质量控制对于确保合金的使用性能和安全性至关重要。以下是对耐蚀镍基合金焊接技术与质量控制的详细探讨。 一、焊接技术 焊条选择 耐蚀镍基合金的焊…

机器视觉与OpenCV--01篇

计算机眼中的图像 像素 像素是图像的基本单位&#xff0c;每个像素存储着图像的颜色、亮度或者其他特征&#xff0c;一张图片就是由若干个像素组成的。 RGB 在计算机中&#xff0c;RGB三种颜色被称为RGB三通道&#xff0c;且每个通道的取值都是0到255之间。 计算机中图像的…

操作系统(14)请求分页

前言 操作系统中的请求分页&#xff0c;也称为页式虚拟存储管理&#xff0c;是建立在基本分页基础上&#xff0c;为了支持虚拟存储器功能而增加了请求调页功能和页面置换功能的一种内存管理技术。 一、基本概念 分页&#xff1a;将进程的逻辑地址空间分成若干个大小相等的页&am…

git企业开发的相关理论(一)

目录 一.初识git 二.git的安装 三.初始化/创建本地仓库 四.配置用户设置/配置本地仓库 五.认识工作区、暂存区、版本库 六.添加文件__场景一 七.查看 .git 文件/添加到本地仓库后.git中发生的变化 1.执行git add后的变化 index文件&#xff08;暂存区&#xff09; log…

wxpython图形用户界面编程

wxpython图形用户界面编程 一、wxpython的基础 1.1 wxpython的基础 作为图形用户界面开发工具包 wxPython&#xff0c;主要提供了如下 GUI 内容&#xff1a; 窗口。控件。事件处理。布局管理。 1.2 wxpython的类层次机构 1.3 wxpython的安装 Windows 和 macOS 平台安装&a…

水仙花数(流程图,NS流程图)

题目&#xff1a;打印出所有的100-999之间的"水仙花数"&#xff0c;并画出流程图和NS流程图。所谓"水仙花数"是指一个三位数&#xff0c;其各位数字立方和等于该数本身。例如&#xff1a;153是一个"水仙花数"&#xff0c;因为1531的三次方&#…

不配置python环境,直接用PyCharm就可以?

有的伙伴可能遇到不安装python环境只安装pycharm也可以进行运行代码。 所以自认为是不需要解释器就可以运行&#xff1f; 这个是不现实的&#xff0c;有很多伙伴可能是安装了Pycharm&#xff0c;但Pycharm看你电脑上没有解释器&#xff0c;所以在安装的时候给你默认安装在C盘…

前端面试汇总(不定时更新)

目录 HTML & CSS1. XML、HTML、XHTML 有什么区别&#xff1f;⭐2. XML和JSON的区别&#xff1f;3. 是否了解W3C的规范&#xff1f;⭐4. 什么是语义化标签&#xff1f;⭐⭐5. 行内元素和块级元素的区别&#xff1f;⭐6. 行内元素和块级元素的转换&#xff1f;⭐7. 常用的块级…

SpringCloud微服务实战系列:03spring-cloud-gateway业务网关灰度发布

目录 spring-cloud-gateway 和zuul spring webflux 和 spring mvc spring-cloud-gateway 的两种模式 spring-cloud-gateway server 模式下配置说明 grayLb://system-server 灰度发布代码实现 spring-cloud-gateway 和zuul zuul 是spring全家桶的第一代网关组件&#x…

ActiveMQ 反序列化漏洞CVE-2015-5254复现

文章目录 一、产生原因二、利用条件三、利用过程四、PoC&#xff08;概念验证&#xff09;五、poc环境验证使用find搜索vulhub已安装目录打开activeMQ组件查看配置文件端口启动镜像-文件配置好后对于Docker 镜像下载问题及解决办法设置好镜像源地址&#xff0c;进行重启docker查…