2025 年 Java 后端面试已转向原理深挖 + 架构实战,大厂不再只问 "怎么用",更追 "底层逻辑"(如 Spring 自动配置、Redis 看门狗机制)。性能优化(26%)、多线程(20%)、数据库优化(18%)是关键。
《2025 Java 后端核心面试宝典》直击高频考点:从 JVM G1、ConcurrentHashMap CAS,到 MySQL MVCC、Kafka 副本策略,再到秒杀削峰、Redis 防穿透方案,全是面试痛点。
帮你跳过零散知识,聚焦 "原理 + 落地",从 "API 调用者" 进阶为 "能解复杂问题的技术人",面试精准得分!
常见MySQL面试题


21. Federated 表是什么?
回答 :
Federated 表是一种特殊的 MySQL 表类型,它允许你从一个 MySQL 服务器访问另一个 MySQL 服务器上的表。这种表不会在本地存储数据,而是通过网络访问远程数据库来进行数据操作。这对于分布式数据库系统或跨服务器查询非常有用。
22. 如果一个表有一列定义为 TIMESTAMP,将发生什么?

回答 :
如果表中的列定义为 TIMESTAMP,则该列会自动存储当前的时间戳(当前时间)。当插入新记录时,TIMESTAMP 列会自动填充当前时间。如果有更新操作,TIMESTAMP 列会在每次更新时自动更新为当前时间,除非使用 DEFAULT 或 ON UPDATE 进行特定配置。
23. 列设置为 AUTO INCREMENT 时,如果在表中达到最大值,会发生什么情况?

回答 :
如果 AUTO_INCREMENT 列达到了最大值(例如,对于 INT 类型,最大值为 2147483647),MySQL 会停止自动增量并发生错误。为了防止这种情况,可以使用更大的整数类型(如 BIGINT),或者手动调整 AUTO_INCREMENT 值。
24. 怎样才能找出最后一次插入时分配了哪个自动增量?
回答 :
可以通过 0 函数获取最后一次插入的 AUTO_INCREMENT 值。例如:
SELECT 0;
该函数返回当前连接中最后一次插入的自增值。
25. 你怎么看到为表格定义的所有索引?
回答 :
可以使用 SHOW INDEX FROM 命令查看一个表上定义的所有索引。例如:
SHOW INDEX FROM table_name;
此命令将返回表上所有索引的详细信息。
26. LIKE 声明中的 % 和 _ 是什么意思?

回答:
%:匹配零个或多个字符。例如,'a%'可以匹配a,abc,a123等。_:匹配单个字符。例如,'a_'可以匹配ab,a1,a2等。
27. 如何在 Unix 和 MySQL 时间戳之间进行转换?
回答 :
在 Unix 时间戳和 MySQL 的 DATETIME 或 TIMESTAMP 类型之间进行转换,可以使用 FROM_UNIXTIME() 和 UNIX_TIMESTAMP() 函数:
-
将 Unix 时间戳转换为 MySQL 时间:
SELECT FROM_UNIXTIME(1632968400);
将 MySQL 时间转换为 Unix 时间戳:
SELECT UNIX_TIMESTAMP('2025-09-24 12:00:00');
28. 列对比运算符是什么?
回答 :
列对比运算符用于比较列的值,常见的对比运算符有:
=(等于)!=或<>(不等于)>(大于)<(小于)>=(大于或等于)<=(小于或等于)
29. 我们如何得到受查询影响的行数?
回答 :
可以使用 ROW_COUNT() 函数来获取受最近执行的查询影响的行数。对于 INSERT、UPDATE、DELETE 等查询都可以使用该函数。例如:
SELECT ROW_COUNT();

记住:大多数后端求职者都和你一样是菜鸟,公司招初级后端更看重的是你的基础扎实度和成长潜力,而不是你现在就能搞定高并发、分布式。放平心态,按计划准备,offer 真的不难拿!