【面试系列】SQL 高频面试题

欢迎来到我的博客,很高兴能够在这里和您见面!欢迎订阅相关专栏:

⭐️ 全网最全IT互联网公司面试宝典:收集整理全网各大IT互联网公司技术、项目、HR面试真题.
⭐️ AIGC时代的创新与未来:详细讲解AIGC的概念、核心技术、应用领域等内容。
⭐️ 全流程数据技术实战指南:全面讲解从数据采集到数据可视化的整个过程,掌握构建现代化数据平台和数据仓库的核心技术和方法。

文章目录

    • SQL 初级面试题及其详细解答
      • 1. 什么是 SQL?简要解释其用途。
      • 2. 如何创建一个新的数据库?
      • 3. 如何创建一个包含三个字段(id、name、age)的表?
      • 4. 如何插入一条记录到上面的表中?
      • 5. 如何查询表中的所有记录?
      • 6. 如何更新表中的某条记录?
      • 7. 如何删除表中的某条记录?
      • 8. 什么是主键?它有什么作用?
      • 9. 如何添加一个名为 `email` 的新列到现有的表中?
      • 10. 如何创建一个包含外键的表?
    • SQL 中级面试题及其详细解答
      • 1. 解释 SQL 连接的类型,并提供示例查询。
      • 2. 什么是索引?如何创建索引?
      • 3. 解释视图的概念,并说明如何创建视图。
      • 4. 如何使用子查询?
      • 5. 如何使用聚合函数(如 COUNT、SUM、AVG、MAX、MIN)?
      • 6. 什么是事务?如何在 MySQL 中使用事务?
      • 7. 如何使用 `GROUP BY` 和 `HAVING` 子句?
      • 8. 如何使用联合(UNION)操作符?
      • 9. 如何在 MySQL 中执行复杂的联表查询?
      • 10. 如何优化 SQL 查询性能?
    • SQL 高级面试题及详细解答
      • 1. 什么是窗口函数(Window Functions)?如何在 SQL 中使用窗口函数?
      • 2. 如何使用递归查询(Recursive Query)?
      • 3. 如何处理日期和时间数据类型的操作?
      • 4. 如何优化复杂查询的性能?
      • 5. 如何处理大数据量的导入和导出?
      • 6. 什么是索引覆盖(Index Coverage)?如何利用索引覆盖优化查询?
      • 7. 如何处理并发和事务一致性?
      • 8. 如何在复杂条件下进行数据过滤和分组?
      • 9. 如何处理空值和重复数据?
      • 10. 如何实现数据库的备份和恢复?
    • 总结
      • 1. 基本 SQL 查询和操作
      • 2. 数据类型和约束
      • 3. 查询优化和性能调优
      • 4. 数据库设计和规范化
      • 5. 高级查询技术
      • 6. 事务管理和并发控制
      • 7. 视图、存储过程和触发器
      • 8. 数据库备份、恢复和安全性
      • 9. SQL 标准和特定数据库系统的差异
      • 10. 错误处理和调试技巧

SQL 初级面试题及其详细解答

1. 什么是 SQL?简要解释其用途。

解答
SQL(结构化查询语言)是一种用于管理和操作关系数据库的标准语言。它用于执行查询、更新、插入、删除和其他数据库操作,帮助用户从数据库中检索所需的数据、定义和修改数据库结构。

2. 如何创建一个新的数据库?

解答
可以使用 CREATE DATABASE 语句来创建一个新的数据库。下面是一个创建名为 mydatabase 的数据库的示例:

CREATE DATABASE mydatabase;

3. 如何创建一个包含三个字段(id、name、age)的表?

解答
可以使用 CREATE TABLE 语句创建一个表。下面是创建名为 persons 的表的示例:

CREATE TABLE persons (id INT AUTO_INCREMENT PRIMARY KEY,name VARCHAR(50),age INT
);

4. 如何插入一条记录到上面的表中?

解答
使用 INSERT INTO 语句插入记录。下面是插入一条记录的示例:

INSERT INTO persons (name, age) VALUES ('Alice', 30);

5. 如何查询表中的所有记录?

解答
使用 SELECT 语句查询所有记录。下面是查询 persons 表中所有记录的示例:

SELECT * FROM persons;

6. 如何更新表中的某条记录?

解答
使用 UPDATE 语句更新记录。下面是将 persons 表中 id 为 1 的记录的 age 更新为 31 的示例:

UPDATE persons SET age = 31 WHERE id = 1;

7. 如何删除表中的某条记录?

解答
使用 DELETE 语句删除记录。下面是删除 persons 表中 id 为 1 的记录的示例:

DELETE FROM persons WHERE id = 1;

8. 什么是主键?它有什么作用?

解答
主键(Primary Key)是表中一列或多列的组合,其值唯一标识表中的每一行记录。主键不允许 NULL 值,确保每条记录的唯一性和完整性。

9. 如何添加一个名为 email 的新列到现有的表中?

解答
使用 ALTER TABLE 语句添加新列。下面是向 persons 表中添加 email 列的示例:

ALTER TABLE persons ADD email VARCHAR(100);

10. 如何创建一个包含外键的表?

解答
使用 FOREIGN KEY 关键字创建包含外键的表。下面是一个示例,其中 orders 表包含一个引用 personsid 的外键:

CREATE TABLE orders (order_id INT AUTO_INCREMENT PRIMARY KEY,order_date DATE,person_id INT,FOREIGN KEY (person_id) REFERENCES persons(id)
);

SQL 中级面试题及其详细解答

1. 解释 SQL 连接的类型,并提供示例查询。

解答
SQL 支持多种连接类型,包括 INNER JOIN、LEFT JOIN、RIGHT JOIN 和 FULL JOIN。每种连接类型用于不同的目的:

  • INNER JOIN:仅返回两个表中匹配的记录。
  • LEFT JOIN:返回左表中的所有记录,以及右表中匹配的记录。
  • RIGHT JOIN:返回右表中的所有记录,以及左表中匹配的记录。
  • FULL JOIN:返回两个表中所有匹配和不匹配的记录。

示例查询:

-- INNER JOIN 示例
SELECT a.id, a.name, b.order_id
FROM persons a
INNER JOIN orders b ON a.id = b.person_id;-- LEFT JOIN 示例
SELECT a.id, a.name, b.order_id
FROM persons a
LEFT JOIN orders b ON a.id = b.person_id;-- RIGHT JOIN 示例
SELECT a.id, a.name, b.order_id
FROM persons a
RIGHT JOIN orders b ON a.id = b.person_id;-- FULL JOIN 示例(MySQL 不直接支持 FULL JOIN,可以通过 UNION 实现)
SELECT a.id, a.name, b.order_id
FROM persons a
LEFT JOIN orders b ON a.id = b.person_id
UNION
SELECT a.id, a.name, b.order_id
FROM persons a
RIGHT JOIN orders b ON a.id = b.person_id;

2. 什么是索引?如何创建索引?

解答
索引是数据库对象,用于加速数据的检索。索引用于快速查找表中的记录,类似于书的索引,可以显著提高查询性能。

创建索引的示例:

-- 创建单列索引
CREATE INDEX idx_name ON persons(name);-- 创建复合索引
CREATE INDEX idx_name_age ON persons(name, age);

3. 解释视图的概念,并说明如何创建视图。

解答
视图是基于 SQL 查询结果的虚拟表。视图提供了一种抽象数据库结构的方法,可以简化复杂查询、提高安全性和提高可读性。

创建视图的示例:

CREATE VIEW person_orders AS
SELECT a.id, a.name, b.order_id, b.order_date
FROM persons a
INNER JOIN orders b ON a.id = b.person_id;

4. 如何使用子查询?

解答
子查询是在另一个 SQL 查询中嵌套的查询,可以用于多种目的,如在 SELECTFROMWHERE 子句中使用。

示例:

-- 查询平均年龄大于所有人的年龄的记录
SELECT name, age
FROM persons
WHERE age > (SELECT AVG(age) FROM persons);

5. 如何使用聚合函数(如 COUNT、SUM、AVG、MAX、MIN)?

解答
聚合函数用于执行计算,如计数、求和、平均、最大和最小值。它们通常与 GROUP BY 子句结合使用。

示例:

SELECT COUNT(*), SUM(age), AVG(age), MAX(age), MIN(age)
FROM persons;

6. 什么是事务?如何在 MySQL 中使用事务?

解答
事务是一个或多个 SQL 语句的集合,这些语句作为一个单元执行。事务具有四个特性(ACID):原子性、一致性、隔离性和持久性。

在 MySQL 中使用事务的示例:

START TRANSACTION;-- 操作1
UPDATE accounts SET balance = balance - 100 WHERE id = 1;-- 操作2
UPDATE accounts SET balance = balance + 100 WHERE id = 2;-- 提交事务
COMMIT;-- 如果出现错误,可以回滚事务
-- ROLLBACK;

7. 如何使用 GROUP BYHAVING 子句?

解答
GROUP BY 子句用于将结果集按一个或多个列进行分组。HAVING 子句用于过滤分组后的结果集。

示例:

-- 按年龄分组并计算每个年龄的数量,过滤数量大于1的组
SELECT age, COUNT(*)
FROM persons
GROUP BY age
HAVING COUNT(*) > 1;

8. 如何使用联合(UNION)操作符?

解答
UNION 操作符用于合并两个或多个 SELECT 语句的结果集。要求每个 SELECT 语句的列数和数据类型相同。

示例:

SELECT name, age FROM persons WHERE age < 30
UNION
SELECT name, age FROM employees WHERE age < 30;

9. 如何在 MySQL 中执行复杂的联表查询?

解答
复杂的联表查询可以通过多次连接和子查询实现。下面是一个示例,展示如何查询包含订单总金额的每个人的信息:

SELECT a.id, a.name, SUM(b.amount) as total_amount
FROM persons a
INNER JOIN orders b ON a.id = b.person_id
GROUP BY a.id, a.name;

10. 如何优化 SQL 查询性能?

解答
优化 SQL 查询性能的方法包括:

  • 使用索引加速数据检索。
  • 避免在索引列上使用函数。
  • 使用适当的连接类型。
  • 减少子查询,使用连接代替。
  • 定期维护和更新统计信息。

示例:

-- 确保查询使用索引
SELECT name FROM persons WHERE age > 30;-- 使用连接代替子查询
SELECT a.name
FROM persons a
INNER JOIN orders b ON a.id = b.person_id
WHERE b.amount > 100;

SQL 高级面试题及详细解答

1. 什么是窗口函数(Window Functions)?如何在 SQL 中使用窗口函数?

解答
窗口函数是一种高级 SQL 技术,用于在查询结果集内执行聚合、排序和分析操作,而不会影响查询结果集的行数。它们通常与 OVER 子句结合使用,支持排名、分区计算等复杂分析。

示例:

SELECT name,age,SUM(age) OVER (PARTITION BY department_id ORDER BY age) AS age_sum_per_department
FROM employees;

2. 如何使用递归查询(Recursive Query)?

解答
递归查询允许在单个查询中迭代查询自身,通常用于处理层次数据结构(如组织结构或评论回复)。在 MySQL 中,使用 WITH RECURSIVE 关键字实现递归查询。

示例:

WITH RECURSIVE cte AS (SELECT id, name, manager_idFROM employeesWHERE id = 1UNION ALLSELECT e.id, e.name, e.manager_idFROM employees eJOIN cte ON e.manager_id = cte.id
)
SELECT * FROM cte;

3. 如何处理日期和时间数据类型的操作?

解答
SQL 提供了许多函数和操作符来处理日期和时间数据类型,如 DATE, TIME, DATETIME, TIMESTAMP。常见操作包括日期计算、格式化、时区转换等。

示例:

-- 计算两个日期之间的天数差
SELECT DATEDIFF('2024-06-30', '2024-01-01');-- 提取日期部分
SELECT DATE_FORMAT('2024-06-30', '%Y-%m-%d');-- 转换时区
SELECT CONVERT_TZ('2024-06-30 12:00:00', '+00:00', '+08:00');

4. 如何优化复杂查询的性能?

解答
优化复杂查询的性能可以通过以下几种方式:

  • 使用索引来加速查询。
  • 避免在 WHERE 子句中使用函数,以允许索引的使用。
  • 分析和优化查询计划,确保最佳执行路径。
  • 使用合适的连接类型(如 INNER JOINLEFT JOIN)以减少不必要的计算。
  • 定期更新统计信息以帮助优化器做出更好的执行计划决策。

5. 如何处理大数据量的导入和导出?

解答
处理大数据量的导入和导出可以使用 SQL 中的 LOAD DATA INFILESELECT INTO OUTFILE 命令。这些命令允许快速、批量地将数据加载到数据库中或从数据库导出。

示例:

-- 从文件导入数据到表
LOAD DATA INFILE '/path/to/data.csv' INTO TABLE mytable FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n';-- 将查询结果导出到文件
SELECT * INTO OUTFILE '/path/to/result.txt' FROM mytable;

6. 什么是索引覆盖(Index Coverage)?如何利用索引覆盖优化查询?

解答
索引覆盖是指查询可以完全通过索引返回所需的数据,而无需访问表中的实际行。这可以显著提高查询性能,因为它减少了从磁盘读取数据的需要。

示例:

-- 创建包含多列的复合索引
CREATE INDEX idx_name_age ON persons(name, age);-- 查询利用索引覆盖
SELECT name, age FROM persons WHERE name = 'Alice' AND age > 30;

7. 如何处理并发和事务一致性?

解答
并发控制和事务一致性是关系数据库管理系统(RDBMS)中非常重要的主题。可以使用事务和锁来确保数据的一致性和可靠性,以避免并发访问时的问题。

示例:

START TRANSACTION;-- 执行多个操作COMMIT; -- 提交事务-- 或者
ROLLBACK; -- 回滚事务

8. 如何在复杂条件下进行数据过滤和分组?

解答
复杂条件下的数据过滤和分组可以通过 CASE 表达式和子查询等方式实现。CASE 表达式可以根据条件返回不同的值,而子查询则可以将结果作为临时表进行进一步处理。

示例:

-- 使用 CASE 表达式进行条件过滤
SELECT id, name,CASEWHEN age < 30 THEN 'Young'WHEN age >= 30 AND age < 50 THEN 'Middle-aged'ELSE 'Senior'END AS age_group
FROM persons;-- 使用子查询进行进一步处理
SELECT age_group, COUNT(*)
FROM (SELECT id, name,CASEWHEN age < 30 THEN 'Young'WHEN age >= 30 AND age < 50 THEN 'Middle-aged'ELSE 'Senior'END AS age_groupFROM persons
) AS age_groups
GROUP BY age_group;

9. 如何处理空值和重复数据?

解答
处理空值可以使用 NULL 值处理函数(如 IFNULL()COALESCE())来替换空值,或者使用 IS NULLIS NOT NULL 运算符进行条件判断。处理重复数据可以使用 DISTINCT 关键字删除重复行。

示例:

-- 替换空值
SELECT id, name, IFNULL(email, 'N/A') AS email
FROM persons;-- 删除重复行
SELECT DISTINCT name, age
FROM persons;

10. 如何实现数据库的备份和恢复?

解答
数据库的备份和恢复可以使用 SQL 中的 mysqldump 工具进行导出和导入。此外,可以定期执行数据库的全量备份和增量备份,以确保数据的安全性和可靠性。

示例:

# 备份数据库
mysqldump -u username -p dbname > backup.sql# 恢复数据库
mysql -u username -p dbname < backup.sql

总结

在 SQL 面试中,候选人需要掌握多个关键知识点和技能,这些知识点涵盖了从基础到高级的各个方面。以下是面试中需要掌握的主要知识点:

1. 基本 SQL 查询和操作

  • SELECT 语句:理解如何使用 SELECT 查询表中的数据,并掌握 DISTINCTWHEREORDER BY 等子句的使用。
  • INSERT、UPDATE、DELETE 语句:了解如何插入、更新和删除表中的数据,掌握如何编写安全有效的数据操作语句。
  • 创建表:使用 CREATE TABLE 语句创建新表,定义表的结构、字段和约束。
  • ALTER 和 DROP TABLE:掌握如何修改和删除表的结构。

2. 数据类型和约束

  • 常见数据类型:如整数、浮点数、字符型、日期时间型等,了解每种数据类型的存储需求和适用场景。
  • 约束:掌握主键、外键、唯一约束、默认值约束、非空约束等的定义和使用,确保数据完整性和一致性。

3. 查询优化和性能调优

  • 索引:理解什么是索引及其工作原理,掌握如何创建、管理和使用索引以提高查询性能。
  • 查询计划分析:了解数据库系统如何执行查询,如何分析查询计划以优化查询效率。
  • 使用 EXPLAIN:掌握如何使用 EXPLAIN 分析查询执行计划,识别潜在的性能瓶颈和优化机会。

4. 数据库设计和规范化

  • 范式和反范式:理解数据库规范化的概念,掌握各个范式的要求和适用场景。
  • 关系图设计:能够设计关系图模型,包括实体、属性、关系和基本规范化步骤。

5. 高级查询技术

  • 子查询:了解如何使用子查询解决复杂查询需求,如在 SELECTFROMWHERE 子句中嵌套使用子查询。
  • 窗口函数:掌握窗口函数的概念和语法,如 OVER 子句的使用,用于执行排名、分析和聚合。
  • 递归查询:了解如何使用递归查询处理层次结构数据,掌握 WITH RECURSIVE 的语法和应用场景。

6. 事务管理和并发控制

  • 事务的 ACID 特性:理解事务的原子性、一致性、隔离性和持久性,如何确保数据的完整性和并发性。
  • 并发控制:了解如何处理并发访问的数据一致性问题,如使用锁、事务隔离级别和乐观锁等技术。

7. 视图、存储过程和触发器

  • 视图:理解视图的概念和作用,如何创建、更新和使用视图简化复杂查询。
  • 存储过程:掌握如何编写和调用存储过程,处理复杂业务逻辑和数据操作。
  • 触发器:了解触发器的作用和使用场景,如何定义触发器以响应表上的数据变更事件。

8. 数据库备份、恢复和安全性

  • 数据备份和恢复:了解如何执行数据库的完全备份和增量备份,确保数据的安全性和可靠性。
  • 数据库安全性:掌握如何管理数据库用户权限、角色和访问控制,确保数据库的安全性和隐私保护。

9. SQL 标准和特定数据库系统的差异

  • SQL 标准:了解 SQL 的标准语法和功能,以及不同数据库系统对标准的扩展和支持。
  • 特定数据库系统:熟悉至少一种主流数据库系统(如 MySQL、PostgreSQL、Oracle、SQL Server)的特性和优化技巧。

10. 错误处理和调试技巧

  • SQL 错误处理:理解如何捕获和处理 SQL 执行过程中的错误和异常情况。
  • 调试技巧:掌握如何使用日志和调试工具分析和解决 SQL 查询和性能问题。

综上所述,SQL 面试涵盖了从基础到高级的广泛知识领域,候选人需要具备良好的理论基础和实际操作经验,以及解决复杂问题的能力。熟练掌握以上知识点可以有效提升在 SQL 面试中的竞争力和表现。


💗💗💗 如果觉得这篇文对您有帮助,请给个点赞、关注、收藏吧,谢谢!💗💗💗

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

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

相关文章

iptable精讲

SNAT策略 SNAT策略的典型应用环境 局域网主机共享单个公网IP地址接入Internet SNAT策略的原理 源地址转换&#xff0c;Source Network Address Translantion 修改数据包的源地址 部署SNAT策略 1.准备二台最小化虚拟机修改主机名 主机名&#xff1a;gw 主机名&#xff1…

【Android面试八股文】为什么要用ContentProvider?它与SQL的实现上有什么区别

一、ContentProvider相比SQL的几个显著的区别和优势 ContentProvider是Android平台上的一个组件,主要用于在不同的应用程序之间共享数据,提供了一种标准化的接口来访问和操作数据。 它与直接使用SQL数据库有几个显著的区别和优势: 数据共享和访问控制: ContentProvider:…

嵌入式以太网硬件构成与MAC、PHY芯片功能介绍

一.以太网电路基本构成 1.总体介绍 对于上述三部分&#xff0c;并不一定都是独立的芯片&#xff0c;主要有以下几种情况&#xff1a; CPU内部集成了MAC和PHY&#xff0c;难度较高&#xff1b; CPU内部集成MAC,PHY采用独立芯片(主流方案)&#xff1b; CPU不集成MAC和PHY&#…

招生报名系统教培招生小程序

招生报名系统&#xff1a;轻松实现教培招生新高度 &#x1f680; 招生报名系统&#xff0c;开启智慧教育新时代 在当今数字化快速发展的时代&#xff0c;教育行业也迎来了变革的浪潮。招生报名系统作为这一变革的先锋&#xff0c;为教育机构提供了全新的招生渠道和管理方式。通…

原型模式的实现

1. 引言 1.1 背景 在实际编程中,有时需要频繁创建多个相似但稍有不同的对象。如果采用传统的对象创建方式,容易造成代码冗余,对象重复初始化操作也可能带来大量的的资源消耗(如时间、内存等)。这样不仅降低了灵活性,导致难以适应状态的变化,还降低了代码的可扩展性。 …

挑战与成长:面对他人成就引发的焦虑与迷茫

挑战与成长&#xff1a;面对他人成就引发的焦虑与迷茫 对于追求知识和技能的人来说&#xff0c;看到他人做出自己尚未达到的成就确实会带来焦虑感。这种焦虑常常源于对自己能力的质疑和对未来的不确定性。 在我的学习和发展过程中&#xff0c;有时确实会看到其他模型或系统能…

实操Nginx+Tomcat多实例部署,实现负载均衡和动静分离

192.168.10.10 192.168.10.20 192.168.10.30 location ~ \.jsp$ {proxy_pass http://192.168.10.50:8080;} location ~ \.(jsp|html)$ {root /usr/share/nginx/html;}192.168.10.40和192.168.10.50用脚本完成搭建此处安装附上脚本&#xff1a; #!/bin/bash# 定义变量 JDK_PACKA…

等保测评——云计算安全扩展(云计算关键技术)

虚拟化技术: 虚拟化是云计算的核心技术之一&#xff0c;它为云计算服务提供基础架构层面的支撑&#xff0c;是ICT&#xff08;信息通信技术&#xff09;服务快速走向云计算的最主要驱动力。虚拟化作为云计算的重要组成部分&#xff0c;最大的好处是能增强系统的弹性和灵活性&a…

【微服务网关——Websocket代理】

1.Websocket协议与原理 1.1 连接建立协议 1.1.1 客户端发起连接请求 客户端通过 HTTP 请求发起 WebSocket 连接。以下是一个 WebSocket 握手请求的例子&#xff1a; GET /chat HTTP/1.1 Host: server.example.com Upgrade: websocket Connection: Upgrade Sec-WebSocket-Key…

题目:只通过+1和×2两种操作,最少几次能把0变成20240701?

偶然在网上看到了一个题目&#xff0c;看了看视频和评论&#xff0c;感觉挺有意思&#xff0c;记录一下。 只通过1和2两种操作&#xff0c;最少几次能把0变成20240701&#xff1f;_哔哩哔哩_bilibili 题目&#xff1a;只通过1和2两种操作&#xff0c;最少几次能把0变成202407…

Python面试宝典第3题:石子游戏

题目 Alice 和 Bob 用几堆石子在做游戏&#xff1a;一共有偶数堆石子&#xff0c;排成一行&#xff1b;每堆都有正整数颗石子&#xff0c;数目为 piles[i] 。游戏以谁手中的石子最多来决出胜负&#xff0c;石子的总数是奇数 &#xff0c;所以没有平局。 Alice 和 Bob 轮流进行&…

CV01_相机成像原理与坐标系之间的转换

目录 0.引言&#xff1a;小孔成像->映射表达式 1. 相机自身的运动如何表征&#xff1f;->外参矩阵E 1.1 旋转 1.2 平移 2. 如何投影到“像平面”&#xff1f;->内参矩阵K 2.1 图像平面坐标转换为像素坐标系 3. 三维到二维的维度是如何丢失的&#xff1f;…

LVS-负载均衡

目录 一、概念 二、LVS工作原理 1. ipvs/ipvsadm 2.名词&#xff1a; 三、常用命令 四、工作模式 1.NAT地址转换模式 &#xff08;1&#xff09;工作流程 &#xff08;2&#xff09;特点 &#xff08;3&#xff09;实验过程 a.环境准备&#xff1a; b.修改测试机的…

UE5 动画蓝图

文章目录 一、State Machines二、Blend Spaces三、Aim Offset四、Montage 初步介绍 Unreal Engine 5 Tutorial - Animation Blueprint Part 1: State Machines (youtube.com) Unreal Engine 5 Tutorial - Animation Blueprint Part 2: Blend Spaces (youtube.com) Unreal Engi…

非静压模型SWASH学习(8)——三维孤立波在锥形岛屿上的爬坡过程(Runup of solitary waves on a conical island)

三维孤立波在锥形岛屿上的爬坡过程&#xff08;Runup of solitary waves on a conical island&#xff09; 算例简介模型配置网格及参数设置网格与地形初始条件与边界条件数值求解方法输出设置模拟时间 波浪&#xff08;孤立波&#xff09;入射边界的时间序列.bnd文件模拟结果注…

HTML5 SVG: 探索矢量图形的新纪元

HTML5 SVG: 探索矢量图形的新纪元 引言 HTML5,作为现代网页开发的核心技术之一,极大地推动了网页内容的丰富性和交互性。在HTML5的众多特性中,SVG(可缩放矢量图形)发挥着重要作用,它允许开发者创建复杂、响应式的矢量图形,这些图形在任何分辨率下都能保持清晰。本文将…

服务器推送有几种方式,分别有什么优缺点

服务器推送主要有以下几种方式&#xff1a; 长轮询&#xff08;Long Polling&#xff09;&#xff1a; 优点&#xff1a; 相对简单易实现。能够在一定程度上减少无效的请求&#xff0c;降低服务器资源消耗。 缺点&#xff1a; 仍然存在一定的延迟。如果连接意外中断&#xff…

[吃瓜教程]南瓜书第4章决策树

1.决策树的算法原理 从逻辑角度&#xff0c;条件判断语句的组合&#xff1b;从几何角度&#xff0c;根据某种准则划分特征空间&#xff1b; 是一种分治的思想&#xff0c;其最终目的是将样本约分约纯&#xff0c;而划分的核心是在条件的选择或者说是**特征空间的划分标准 ** …

Mamba项目实战-Ubuntu

注&#xff1a;演示环境需要一个可用的cuda环境&#xff0c;可执行两个命令进行验证 1.nvidia-smi 2.nvcc -V 若出现正确输出&#xff0c;可继续博客以下的操作步骤&#xff0c;否则请确认是否已经安装或已配置环境变量&#xff0c;若未安装则转到博客&#xff1a;深度学习项…

mac安装达梦数据库

参考&#xff1a;mac安装达梦数据库​​​​​​ 实践如下&#xff1a; 1、下载达梦Docker镜像文件 同参考链接 2、导入镜像 镜像可以随便放在某个目录&#xff0c;相当于安装包&#xff0c;导入后就没有作用了。 查找达梦镜像名称&#xff1a;dm8_20240613_rev229704_x86…