有在网上找做网站的人么/超级外链工具有用吗

有在网上找做网站的人么,超级外链工具有用吗,css网站怎么做,微信怎么做网站的动图WHERE 子句优化 截至2024年7月,MySQL最新稳定版本是8.2,并不存在MySQL 8.4 。下面从常见的几个方面为你介绍 MySQL 8.x 中 WHERE 子句的优化方法: 1. 确保使用索引 原理:索引可以加快数据的查找速度,当 WHERE 子句中的条件列有索引时,MySQL 可以直接定位到符合条件的数…

WHERE 子句优化

截至2024年7月,MySQL最新稳定版本是8.2,并不存在MySQL 8.4 。下面从常见的几个方面为你介绍 MySQL 8.x 中 WHERE 子句的优化方法:

1. 确保使用索引

  • 原理:索引可以加快数据的查找速度,当 WHERE 子句中的条件列有索引时,MySQL 可以直接定位到符合条件的数据,而不需要全表扫描。
  • 示例
-- 创建一个表
CREATE TABLE users (id INT PRIMARY KEY,name VARCHAR(50),age INT,email VARCHAR(100)
);-- 为 age 列创建索引
CREATE INDEX idx_age ON users (age);-- 查询 age 大于 20 的用户
SELECT * FROM users WHERE age > 20;

在这个例子中,通过为 age 列创建索引,当执行 WHERE 子句中包含 age 条件的查询时,MySQL 可以利用该索引快速定位符合条件的记录,提高查询效率。

2. 避免在索引列上使用函数

  • 原理:如果在索引列上使用函数,MySQL 无法使用该索引进行快速查找,会导致全表扫描。
  • 错误示例
-- 查询 name 以 'J' 开头的用户,这里使用了函数,无法使用索引
SELECT * FROM users WHERE LEFT(name, 1) = 'J';
  • 正确示例
-- 使用 LIKE 操作符代替函数,可使用索引
SELECT * FROM users WHERE name LIKE 'J%';

3. 优化范围查询

  • 原理:范围查询(如 ><BETWEEN 等)可能会导致索引失效,特别是在复合索引中。尽量将范围查询放在条件的最后。
  • 示例
-- 创建复合索引
CREATE INDEX idx_age_name ON users (age, name);-- 优化后的查询,将范围查询放在最后
SELECT * FROM users WHERE name = 'John' AND age > 20;

在这个例子中,先通过 name 列进行精确匹配,再进行 age 列的范围查询,这样可以更有效地利用复合索引。

4. 避免使用 OR 连接条件

  • 原理:当 WHERE 子句中使用 OR 连接多个条件时,MySQL 可能无法使用索引,导致全表扫描。可以使用 UNION 代替 OR
  • 错误示例
-- 使用 OR 连接条件,可能无法使用索引
SELECT * FROM users WHERE age = 20 OR age = 30;
  • 正确示例
-- 使用 UNION 代替 OR,可使用索引
SELECT * FROM users WHERE age = 20
UNION
SELECT * FROM users WHERE age = 30;

通过以上优化方法,可以显著提高 WHERE 子句的查询性能,减少数据库的响应时间。

范围优化

在 MySQL 中,范围查询(如使用 ><>=<=BETWEEN 等操作符)是常见的查询需求,但如果处理不当,可能会导致性能问题。以下从多个方面介绍范围查询的优化方法:

1. 索引优化

合理创建索引
  • 对于经常用于范围查询的列,应该创建合适的索引。例如,如果经常对 users 表的 age 列进行范围查询,就可以为 age 列创建索引。
-- 创建 users 表
CREATE TABLE users (id INT PRIMARY KEY,name VARCHAR(50),age INT
);
-- 为 age 列创建索引
CREATE INDEX idx_age ON users (age);
  • 当执行 SELECT * FROM users WHERE age > 20; 这样的范围查询时,MySQL 可以利用 idx_age 索引快速定位到符合条件的记录。
复合索引的使用与顺序
  • 当查询涉及多个列的范围条件时,需要合理创建复合索引。例如,有一个查询 SELECT * FROM orders WHERE order_date BETWEEN '2024-01-01' AND '2024-12-31' AND amount > 1000;,可以创建一个包含 order_dateamount 的复合索引。
-- 创建 orders 表
CREATE TABLE orders (order_id INT PRIMARY KEY,order_date DATE,amount DECIMAL(10, 2)
);
-- 创建复合索引
CREATE INDEX idx_order_date_amount ON orders (order_date, amount);
  • 复合索引中列的顺序很重要,一般将选择性高的列放在前面。在这个例子中,order_date 的选择性可能更高,所以放在前面。

2. 查询语句优化

避免在索引列上使用函数
  • 在范围查询的条件中,如果对索引列使用函数,会导致索引失效。例如,以下查询无法使用 age 列的索引:
SELECT * FROM users WHERE YEAR(birth_date) > 1990;
  • 可以将其改写为不使用函数的形式:
SELECT * FROM users WHERE birth_date > '1990-12-31';
范围条件的位置
  • 在复合索引中,范围查询条件尽量放在后面。例如,对于复合索引 (col1, col2, col3),如果查询条件为 col1 = 'value1' AND col2 > 10 AND col3 = 'value3',应该将 col2 > 10 这个范围条件放在最后,因为 MySQL 在使用复合索引时,遇到范围查询后,后续的索引列可能无法有效使用。

3. 数据库配置优化

调整缓冲池大小
  • 缓冲池(InnoDB Buffer Pool)用于缓存数据和索引页,适当增大缓冲池的大小可以提高范围查询的性能。可以通过修改 innodb_buffer_pool_size 参数来调整缓冲池大小。例如,在 my.cnfmy.ini 配置文件中添加或修改以下内容:
[mysqld]
innodb_buffer_pool_size = 2G
  • 上述配置将缓冲池大小设置为 2GB,具体大小需要根据服务器的内存和实际业务情况进行调整。
调整查询缓存
  • 查询缓存可以缓存查询结果,对于相同的范围查询,如果结果已经被缓存,就可以直接返回,减少查询时间。可以通过设置 query_cache_typequery_cache_size 参数来启用和调整查询缓存的大小。例如:
[mysqld]
query_cache_type = 1
query_cache_size = 64M
  • 不过,需要注意的是,查询缓存对于频繁更新的表可能效果不佳,因为每次表更新时,相关的查询缓存都会失效。

4. 数据分区优化

按范围分区
  • 对于数据量较大的表,可以考虑使用数据分区。例如,对于 orders 表,可以按照 order_date 进行范围分区。
-- 创建按范围分区的 orders 表
CREATE TABLE orders (order_id INT,order_date DATE,amount DECIMAL(10, 2)
)
PARTITION BY RANGE (YEAR(order_date)) (PARTITION p2023 VALUES LESS THAN (2024),PARTITION p2024 VALUES LESS THAN (2025),PARTITION p2025 VALUES LESS THAN (2026)
);
  • 当执行范围查询 SELECT * FROM orders WHERE order_date BETWEEN '2024-01-01' AND '2024-12-31'; 时,MySQL 只需要在 p2024 分区中查找数据,减少了扫描的数据量。

索引合并优化

索引合并优化(Index Merge Optimization)是 MySQL 数据库中的一种重要优化策略,当一个查询的 WHERE 子句中包含多个条件,且每个条件都可以使用不同的索引时,MySQL 可以通过索引合并的方式来提高查询效率。以下为你详细介绍索引合并优化的相关内容:

1. 索引合并的类型

交集合并(Intersection Merge)
  • 原理:当查询的条件可以通过多个索引分别筛选出一部分结果,并且这些结果需要同时满足时,MySQL 会使用交集合并。即通过多个索引分别定位到符合各自条件的记录,然后取这些记录的交集。
  • 示例
-- 创建表
CREATE TABLE products (id INT PRIMARY KEY,category_id INT,price DECIMAL(10, 2),INDEX idx_category (category_id),INDEX idx_price (price)
);
-- 插入示例数据
INSERT INTO products (id, category_id, price) VALUES (1, 1, 10.00), (2, 2, 20.00), (3, 1, 30.00);
-- 查询语句
SELECT * FROM products 
WHERE category_id = 1 AND price > 20;

在这个例子中,idx_category 索引可以快速定位 category_id = 1 的记录,idx_price 索引可以快速定位 price > 20 的记录,MySQL 会对这两个索引的结果取交集,得到最终符合条件的记录。

并集合并(Union Merge)
  • 原理:当查询的条件可以通过多个索引分别筛选出一部分结果,并且这些结果只需要满足其中一个条件即可时,MySQL 会使用并集合并。即通过多个索引分别定位到符合各自条件的记录,然后取这些记录的并集。
  • 示例
SELECT * FROM products 
WHERE category_id = 1 OR price > 20;

在这个例子中,idx_category 索引定位 category_id = 1 的记录,idx_price 索引定位 price > 20 的记录,MySQL 会将这两个索引的结果合并,得到最终符合条件的记录。

排序并集合并(Sort-Union Merge)
  • 原理:当并集合并的结果需要排序时,MySQL 会使用排序并集合并。它会先通过多个索引分别定位到符合各自条件的记录,然后将这些记录合并,并进行排序。
  • 示例
SELECT * FROM products 
WHERE category_id = 1 OR price > 20
ORDER BY id;

在这个例子中,除了进行并集合并外,还需要对结果按照 id 进行排序,MySQL 会使用排序并集合并来完成这个操作。

2. 索引合并优化的条件

  • 多个独立索引:查询的 WHERE 子句中必须有多个条件,且每个条件都可以使用不同的独立索引。
  • 索引类型支持:目前 MySQL 支持对 BTREE 索引进行索引合并优化,其他类型的索引可能不支持。
  • 查询复杂度:查询的复杂度不能过高,否则 MySQL 可能会选择其他的优化策略。

3. 查看索引合并优化是否生效

可以使用 EXPLAIN 语句来查看查询是否使用了索引合并优化。例如:

EXPLAIN SELECT * FROM products 
WHERE category_id = 1 AND price > 20;

EXPLAIN 的结果中,如果 Extra 列显示 Using index merge; Using intersect(idx_category,idx_price),则表示使用了交集合并优化;如果显示 Using index merge; Using union(idx_category,idx_price),则表示使用了并集合并优化。

4. 索引合并优化的局限性

  • 性能开销:虽然索引合并可以提高查询效率,但在某些情况下,合并多个索引的结果也会带来一定的性能开销,特别是当索引结果集较大时。
  • 复合索引优先:如果可以通过创建复合索引来满足查询需求,通常复合索引的性能会优于索引合并。例如,对于上述 products 表,如果经常执行 WHERE category_id = 1 AND price > 20 这样的查询,可以创建复合索引 CREATE INDEX idx_category_price ON products (category_id, price);

哈希联接优化

哈希联接(Hash Join)是数据库中用于连接两个表的一种重要算法,在 MySQL 等数据库系统中,通过合理运用哈希联接优化策略,可以显著提升查询性能。下面从哈希联接的原理、优化方法、使用场景、局限性等方面详细介绍。

原理

哈希联接主要用于处理两个表之间的连接操作,其基本步骤如下:

  1. 构建阶段(Build Phase):选择较小的表(通常称为构建表),对连接键(用于连接两个表的列)进行哈希运算,将表中的每一行数据根据哈希值存储到对应的哈希桶中,形成一个哈希表。
  2. 探查阶段(Probe Phase):遍历较大的表(通常称为探查表),对探查表中的每一行数据的连接键执行相同的哈希运算,根据哈希值找到对应的哈希桶,然后在该哈希桶中查找匹配的行,从而完成连接操作。

优化方法

1. 表大小选择
  • 原理:由于构建哈希表需要消耗一定的内存和时间,选择较小的表作为构建表可以减少构建哈希表的开销,提高整体性能。
  • 示例:假设有两个表 orderscustomersorders 表数据量较大,customers 表数据量较小,在进行连接查询时,可以让 MySQL 优先选择 customers 表作为构建表。
-- 连接查询示例
SELECT * 
FROM orders
JOIN customers ON orders.customer_id = customers.customer_id;
2. 内存分配
  • 原理:足够的内存可以确保哈希表能够完整地存储在内存中,避免频繁的磁盘 I/O 操作。可以通过调整相关的系统参数来增加哈希联接的内存分配。
  • 示例:在 MySQL 中,可以通过修改 join_buffer_size 参数来增加连接缓冲区的大小,该缓冲区可用于存储哈希表。
-- 在 my.cnf 或 my.ini 配置文件中修改参数
[mysqld]
join_buffer_size = 2M
3. 数据类型匹配
  • 原理:确保连接键的数据类型一致,避免在连接过程中进行数据类型转换,因为数据类型转换会增加额外的计算开销,影响性能。
  • 示例:如果 orders 表和 customers 表的 customer_id 列都是 INT 类型,在进行连接操作时就不会有数据类型转换的问题。
-- 创建表时确保数据类型一致
CREATE TABLE orders (order_id INT,customer_id INT
);CREATE TABLE customers (customer_id INT,customer_name VARCHAR(50)
);

使用场景

  • 大数据集连接:当需要连接两个大数据集时,哈希联接通常比嵌套循环联接(Nested Loop Join)等其他连接算法更高效,因为它可以减少不必要的比较次数。
  • 无索引连接:当连接键上没有合适的索引时,哈希联接可以发挥较好的性能,因为它不需要依赖索引来查找匹配的行。

局限性

  • 内存需求:哈希联接需要足够的内存来存储哈希表,如果内存不足,可能会导致哈希表溢出到磁盘,从而产生大量的磁盘 I/O 操作,严重影响性能。
  • 数据倾斜:如果连接键的数据分布不均匀,可能会导致某些哈希桶中的数据过多,而其他哈希桶中的数据过少,这种数据倾斜问题会影响哈希联接的性能。例如,某些 customer_id 出现的频率远高于其他 customer_id,会导致对应的哈希桶数据量过大。

查看哈希联接是否使用

可以使用 EXPLAIN 语句来查看查询是否使用了哈希联接。例如:

EXPLAIN SELECT * 
FROM orders
JOIN customers ON orders.customer_id = customers.customer_id;

EXPLAIN 的结果中,如果 Extra 列显示与哈希联接相关的信息,如 Using hash join,则表示使用了哈希联接。

引擎条件下推优化

引擎条件下推优化

定义

引擎条件下推优化(Engine Condition Pushdown Optimization)是数据库管理系统(如 MySQL)中一种重要的查询优化技术。其核心思想是将部分查询条件尽可能早地传递给存储引擎进行处理,而不是在服务器层过滤数据,从而减少从存储引擎传输到服务器层的数据量,提高查询性能。

原理

在传统的查询处理流程中,存储引擎会将满足索引条件的所有数据行返回给服务器层,然后服务器层再根据 WHERE 子句中的其他条件对这些数据行进行过滤。而引擎条件下推优化打破了这种模式,它允许存储引擎在检索数据时就利用额外的查询条件进行过滤,只将符合这些条件的数据行返回给服务器层。

示例

假设有一个 employees 表,包含 employee_iddepartment_idsalaryhire_date 等列,并且在 department_id 列上有索引。执行以下查询:

SELECT * 
FROM employees 
WHERE department_id = 10 AND salary > 5000;
  • 未使用引擎条件下推优化:存储引擎会根据 department_id 索引找到所有 department_id = 10 的数据行,然后将这些行全部返回给服务器层。服务器层再对这些返回的数据行进行筛选,过滤出 salary > 5000 的行。
  • 使用引擎条件下推优化:存储引擎不仅会利用 department_id 索引找到 department_id = 10 的数据行,还会在检索过程中同时检查 salary > 5000 这个条件,只将同时满足这两个条件的数据行返回给服务器层,减少了数据传输量和服务器层的处理负担。
开启和限制
  • 开启:在 MySQL 中,默认情况下引擎条件下推优化是开启的。可以通过设置 optimizer_switch 系统变量来控制其开关状态,例如:
-- 开启引擎条件下推优化
SET optimizer_switch = 'engine_condition_pushdown=on';
  • 限制:并非所有的查询条件都能进行下推,例如包含子查询、函数调用或某些复杂表达式的条件可能无法下推到存储引擎进行处理。

索引条件下推优化(Index Condition Pushdown Optimization)

索引条件下推优化(Index Condition Pushdown Optimization)

定义

索引条件下推(Index Condition Pushdown,简称 ICP)是 MySQL 数据库中一种重要的查询优化技术,主要用于提升查询性能。该优化技术允许 MySQL 在使用索引进行数据检索时,将部分 WHERE 子句中的条件下推到存储引擎层进行过滤,而不是像传统方式那样将所有满足索引范围的记录都返回给服务器层,再由服务器层进行过滤。

原理
  • 传统查询流程:在没有使用 ICP 优化时,存储引擎根据索引定位到符合索引条件的记录后,会将这些记录全部返回给服务器层,服务器层再根据 WHERE 子句中的其他条件进行过滤。
  • ICP 优化流程:当启用 ICP 时,存储引擎会在索引扫描过程中,将 WHERE 子句中可以使用索引进行判断的条件下推到存储引擎层进行过滤。只有满足这些条件的记录才会被读取并返回给服务器层,这样可以显著减少从存储引擎传输到服务器层的数据量,从而提高查询效率。
示例

假设有一个 employees 表,包含 idnamedepartment_idsalary 等列,并且在 department_idname 上创建了复合索引 idx_department_name (department_id, name)。执行以下查询:

SELECT * 
FROM employees 
WHERE department_id = 10 AND name LIKE 'J%';
  • 未使用 ICP 优化:存储引擎根据 idx_department_name 索引找到所有 department_id = 10 的记录,然后将这些记录全部返回给服务器层。服务器层再对这些记录进行过滤,筛选出 name LIKE 'J%' 的记录。
  • 使用 ICP 优化:存储引擎在扫描 idx_department_name 索引时,会同时检查 department_id = 10name LIKE 'J%' 这两个条件。只有同时满足这两个条件的记录才会被读取并返回给服务器层,减少了不必要的数据传输和服务器层的处理负担。
开启和关闭
  • 默认情况:在 MySQL 5.6 及以上版本中,索引条件下推优化默认是开启的。
  • 手动控制:可以通过设置 optimizer_switch 系统变量来开启或关闭 ICP 优化。例如:
-- 开启 ICP 优化
SET optimizer_switch = 'index_condition_pushdown=on';
-- 关闭 ICP 优化
SET optimizer_switch = 'index_condition_pushdown=off';
适用场景和限制
  • 适用场景:当查询条件中包含可以使用索引进行过滤的部分,且表的数据量较大时,ICP 优化可以显著提高查询性能。
  • 限制:ICP 优化只适用于 MyISAMInnoDB 存储引擎。对于某些复杂的查询条件,如包含子查询、函数调用等,可能无法进行有效的 ICP 优化。

引擎条件下推优化和索引条件下推优化(Index Condition Pushdown Optimization)感觉是同一个东西?

引擎条件下推优化和索引条件下推优化有相似之处,但并不是同一个东西,下面从概念、条件应用范围、适用场景等方面来详细分析它们的区别和联系:

相似点

  • 核心目标一致:二者的主要目的都是为了减少从存储引擎传输到服务器层的数据量,从而提高查询性能。它们都尝试将原本在服务器层进行的部分过滤操作提前到存储引擎层执行,避免不必要的数据传输和处理。
  • 优化方式类似:都是通过将查询条件下推到更底层(存储引擎)来进行过滤,使得服务器层可以处理更少的数据,进而加快查询速度。

不同点

概念范畴
  • 引擎条件下推优化:是一个更宽泛的概念,它指的是将查询中的部分条件尽可能早地传递给存储引擎进行处理,这些条件不局限于索引相关的条件。只要存储引擎能够处理这些条件,就可以进行下推。
  • 索引条件下推优化(ICP):是一种特定的、基于索引的优化技术。它主要针对 WHERE 子句中那些可以利用索引进行判断的条件,将这些条件下推到存储引擎在索引扫描过程中进行过滤。
条件应用范围
  • 引擎条件下推优化:可以处理更多类型的条件,不仅仅依赖于索引。例如,一些不涉及索引列但存储引擎能够处理的条件也可能会被下推。
  • 索引条件下推优化:只关注那些可以利用索引来评估的条件。如果查询条件不能通过索引进行判断,就不会应用 ICP 优化。
适用场景
  • 引擎条件下推优化:适用于各种存储引擎和查询场景,尤其是当查询条件较为复杂,包含非索引列的过滤条件时,该优化可以发挥作用。
  • 索引条件下推优化:主要适用于存在合适索引的查询场景。当查询可以使用索引来定位数据,并且 WHERE 子句中有基于索引列的过滤条件时,ICP 优化能够显著提高性能。
示例对比
  • 引擎条件下推优化示例
SELECT * 
FROM products 
WHERE category = 'electronics' AND weight > 10;

如果存储引擎能够在数据读取时同时处理 category = 'electronics'weight > 10 这两个条件,那么引擎条件下推优化会将这两个条件都下推到存储引擎进行过滤。

  • 索引条件下推优化示例
SELECT * 
FROM employees 
WHERE department_id = 10 AND name LIKE 'J%';

假设在 department_idname 上有复合索引,索引条件下推优化会将 department_id = 10name LIKE 'J%' 这两个基于索引列的条件下推到存储引擎在索引扫描时进行过滤。

嵌套循环连接算法(Nested - Loop Join Algorithms)

在 MySQL 中,嵌套循环连接算法(Nested - Loop Join Algorithms)是用于执行表连接操作的基本算法之一,它有多种变体,每种变体在不同场景下具有不同的性能表现。下面为你详细介绍这些算法及其在 MySQL 中的应用。

1. 简单嵌套循环连接(Simple Nested - Loop Join,SNLJ)

原理

简单嵌套循环连接是最基础的嵌套循环连接算法。它使用两层嵌套循环,外层循环遍历驱动表的每一行,对于驱动表的每一行,内层循环遍历被驱动表的所有行,检查是否满足连接条件,若满足则将这两行组合添加到结果集中。

示例 SQL 及分析
SELECT * 
FROM table1
JOIN table2 ON table1.id = table2.id;

当 MySQL 采用简单嵌套循环连接算法执行该查询时,会逐行读取 table1 中的每一行,然后针对 table1 中的每一行,遍历 table2 中的所有行,比较 table1.idtable2.id 是否相等。

性能特点

时间复杂度为 O ( m ∗ n ) O(m * n) O(mn),其中 m m m 是驱动表的行数, n n n 是被驱动表的行数。当表的数据量较大时,性能会非常差,因为需要进行大量的比较操作。

2. 块嵌套循环连接(Block Nested - Loop Join,BNLJ)

原理

为了减少内层循环中被驱动表的扫描次数,块嵌套循环连接引入了一个缓冲区。它将驱动表的数据分成多个块,每次将一个块的数据加载到缓冲区中,然后对被驱动表进行一次扫描,将缓冲区中的每一行与被驱动表的每一行进行比较。

示例 SQL 及分析
SELECT * 
FROM orders
JOIN customers ON orders.customer_id = customers.customer_id;

假设 orders 表是驱动表,customers 表是被驱动表。MySQL 会将 orders 表的数据按一定大小分成块,每次将一个块的数据放入 join_buffer 中,然后扫描 customers 表,将 join_buffer 中的

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

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

相关文章

11.【线性代数】——矩阵空间,秩1矩阵,小世界图

十一 矩阵空间&#xff0c;秩1矩阵&#xff0c;小世界图 1. 矩阵空间交集 和 和集 2. 所有解空间3. r 1 r1 r1的矩阵4. 题目5. 小世界图 空间&#xff1a;组成空间的元素的线性组合都在这个空间中。 1. 矩阵空间 举例&#xff1a;矩阵空间&#xff08; M M M 所有3x3的矩阵&…

【网络安全 | 渗透测试】GraphQL精讲一:基础知识

未经许可,不得转载, 文章目录 GraphQL 定义GraphQL 工作原理GraphQL 模式GraphQL 查询GraphQL 变更(Mutations)查询(Queries)和变更(Mutations)的组成部分字段(Fields)参数(Arguments)变量别名(Aliases)片段(Fragments)订阅(Subscriptions)自省(Introspecti…

关于虚拟环境中遇到的bug

conda和cmd介绍 介绍 Conda 概述&#xff1a; Conda是一个开源包管理系统和环境管理系统&#xff0c;尤其适用于Python和R语言的开发环境。它允许用户创建独立的虚拟环境&#xff0c;方便地管理依赖包和软件版本。 特点&#xff1a; 环境管理&#xff1a;可以创建、导入、导…

网络安全法与等级保护 PPT 精华汇总

资源描述 本资源文件为《网络安全法与等级保护》的PPT精华汇总&#xff0c;内容涵盖了网络安全法与等级保护的总体框架及相关标准规范。该PPT详细介绍了网络安全法与等级保护的各个章节和条款&#xff0c;并提供了基础类和应用类的相关标准文件&#xff0c;帮助读者全面了解和…

uni-app开发安卓和iOS 打包流程(云打包)

首先讲一下安卓打包的流程,之后再说ios。打包安卓和iOS打包的流程有些不同,安卓打包相对来说比较简单,而iOS打包需要更多的准备工作,如申请开发者账号、生成证书等。 一、安卓打包 1、安卓打包直接在window电脑上就可以操作,打开hbuilderx,找到你的项目选中,然后点击发…

摄像头应用编程(四):ARM Linux LCD实时预览UVC摄像头画面

文章目录 1、前言2、环境介绍3、步骤4、应用程序编写4.1、lcd初始化4.2、摄像头初始化4.3、jpeg解码4.4、开启摄像头4.5、完整的程序如下 5、测试5.1、编译应用程序5.2、运行应用程序 6、总结 1、前言 本次应用程序主要针对支持MJPEG格式输出的UVC摄像头。 2、环境介绍 rk35…

蓝桥与力扣刷题(蓝桥 k倍区间)

题目&#xff1a;给定一个长度为 N 的数列&#xff0c;A1,A2,⋯AN​&#xff0c;如果其中一段连续的子序列 Ai,Ai1,⋯Aj( i≤j ) 之和是 K 的倍数&#xff0c;我们就称这个区间[i,j] 是 K 倍区间。 你能求出数列中总共有多少个 K 倍区间吗&#xff1f; 输入描述 第一行包含两…

json介绍、python数据和json数据的相互转换

目录 一 json介绍 json是什么&#xff1f; 用处 Json 和 XML 对比 各语言对Json的支持情况 Json规范详解 二 python数据和json数据的相互转换 dumps() : 转换成json loads(): 转换成python数据 总结 一 json介绍 json是什么&#xff1f; 实质上是一条字符串 是一种…

单细胞分析(20)——inferCNV分析

InferCNV分析笔记 1. 分析目标 InferCNV&#xff08;Inference of Copy Number Variations&#xff09;是一种基于单细胞转录组数据推断**拷贝数变异&#xff08;CNV&#xff09;**的方法&#xff0c;推测其基因组变异情况。 2. 数据准备 2.1 载入数据 library(Seurat) set…

C++:多态与虚函数

1.虚函数&#xff0c;在函数前加virtual即可。有虚函数时&#xff0c;父类指针指向父类对象时就会使用父类的成员&#xff0c;指向子类对象时就可以使用子类成员&#xff0c;进而我们引入了多态的概念。 2.多态&#xff1a;父类指针指向子类的对象&#xff0c;通过父类指针调用…

WSL下使用git克隆失败解决

WSL默认nat模式&#xff0c;别动了防火墙放行&#xff0c;见图1git导入[bash1]&#xff0c;ip为你wsl上linxu通过ifconfig获取的本机ip&#xff0c;端口对好某alcsh软件开启tun模式【经过测试&#xff0c;不开也行】应该成了&#xff0c;如果不行&#xff0c;修改.wslconfig为下…

开放鸿蒙OpenHarmony 5.0.0 Release 兼容性测试实战经验分享

OpenHarmony 5.0版本的发布时间是2024年12月20日至21日。这个版本带来了许多新特性和改进。现在5.0出了两个release 版本&#xff0c;分别是5.0.0和5.0.1。 就在5.0版本发布不到2周的时间内&#xff0c;2025年01月01日起&#xff0c;不支持新产品基于老分支&#xff08;OpenHar…

Oracle OCP认证考试考点详解083系列01

题记&#xff1a; 本系列主要讲解Oracle OCP认证考试考点&#xff08;题目&#xff09;&#xff0c;适用于19C/21C,跟着学OCP考试必过。 1. 第1题&#xff1a; 题目 解析及答案&#xff1a; 关于自动工作量存储库&#xff08;AWR&#xff09;快照&#xff0c;以下哪三个选项…

从DNS到TCP:DNS解析流程和浏览器输入域名访问流程

1 DNS 解析流程 1.1 什么是DNS域名解析 在生活中我们会经常遇到域名&#xff0c;比如说CSDN的域名www.csdn.net&#xff0c;百度的域名www.baidu.com,我们也会碰到IP&#xff0c;现在目前有的是IPV4&#xff0c;IPV6。那这两个有什么区别呢&#xff1f;IP地址是互联网上计算机…

word转换为pdf后图片失真解决办法、高质量PDF转换方法

1、安装Adobe Acrobat Pro DC 自行安装 2、配置Acrobat PDFMaker &#xff08;1&#xff09;点击word选项卡上的Acrobat插件&#xff0c;&#xff08;2&#xff09;点击“首选项”按钮&#xff0c;&#xff08;3&#xff09;点击“高级配置”按钮&#xff08;4&#xff09;点…

C++20 标准化有符号整数:迈向更可预测的整数运算

文章目录 一、背景&#xff1a;为什么需要标准化&#xff1f;二、2 的补码&#xff1a;原理与优势&#xff08;一&#xff09;2 的补码原理&#xff08;二&#xff09;2 的补码的优势 三、C20 的变化&#xff1a;明确 2 的补码四、如何利用这一特性优化代码&#xff08;一&…

Libgdx游戏开发系列教程(1)——环境配置及demo运行

目录 环境 JDK环境 项目创建 1.下载gdx-setup.jar文件 2.填写信息,创建项目 demo运行步骤 1.修改gradle.properties 2.安装Build-Tool 3.运行 Libgdx游戏是基于Java的一款游戏引擎,可以发布Android,桌面端,Html,IOS等游戏,出名的《杀戮尖塔》也是用了此引擎制作的 本…

【jenkins配置记录】

全局工具配置&#xff1a; D:\Program Files\Java\jdk1.8.0_281 D:\Program Files\Git\bin\git.exe E:\allure-2.13.2 2. GIT 3. 定时任务 H 8 * * 1-5 4. 构建触发器 5. 构建后操作 Allure Report 吐血记录&#xff1a;报告路径可以为 workspace 相对路径 6. 系统配置 em…

Linux网络相关概念和重要知识(1)(网络协议、网络通信)

目录 1.网络协议 &#xff08;1&#xff09;网络的起源 &#xff08;2&#xff09;为什么需要协议 &#xff08;3&#xff09;协议分层及其设计的解耦 &#xff08;4&#xff09;OSI定义的七层网络模型 ①分层及其功能 ②TCP/IP协议 ③传输层协议&#xff08;TCP和UDP&a…

Linux操作系统5-进程信号2(信号的4种产生方式,signal系统调用)

上篇文章&#xff1a;Linux操作系统5-进程信号1&#xff08;信号基础&#xff09;-CSDN博客 本篇Gitee仓库&#xff1a;myLerningCode/l25 橘子真甜/Linux操作系统与网络编程学习 - 码云 - 开源中国 (gitee.com) 本篇重点&#xff1a;信号的4种产生 目录 一. signal系统调用 …