MySQL偏门但基础的面试题集锦

文章目录

    • [1. TIMESTAMP和DATETIME的微妙区别?](#1. TIMESTAMP和DATETIME的微妙区别?)
    • [2. VARCHAR(255)和VARCHAR(256)的存储差异?](#2. VARCHAR(255)和VARCHAR(256)的存储差异?)
    • [3. COUNT(*)、COUNT(1)、COUNT(字段)的区别?](#3. COUNT(*)、COUNT(1)、COUNT(字段)的区别?)
    • [4. LIMIT 1000000, 10为什么这么慢?](#4. LIMIT 1000000, 10为什么这么慢?)
    • [5. 为什么InnoDB表必须有主键?](#5. 为什么InnoDB表必须有主键?)
    • [6. MySQL的隐式类型转换规则?](#6. MySQL的隐式类型转换规则?)
    • [7. DELETE FROM table和TRUNCATE的隐藏区别?](#7. DELETE FROM table和TRUNCATE的隐藏区别?)

1. TIMESTAMP和DATETIME的微妙区别?

  • TIMESTAMP存储UTC时间,会根据当前时区转换显示
  • DATETIME存储的是字面值,不受时区影响
  • TIMESTAMP范围:1970-2038年,DATETIME范围:1000-9999年
  • TIMESTAMP在UPDATE时可以自动更新为当前时间

2. VARCHAR(255)和VARCHAR(256)的存储差异?

sql 复制代码
-- VARCHAR(255):长度用1字节存储
-- VARCHAR(256):长度用2字节存储
CREATE TABLE test_varchar (
    col1 VARCHAR(255),  -- 最大占用255+1=256字节
    col2 VARCHAR(256)   -- 最大占用256+2=258字节
);
  • VARCHAR长度≤255时,用1字节存储长度信息
  • VARCHAR长度>255时,用2字节存储长度信息

3. COUNT(*)、COUNT(1)、COUNT(字段)的区别?

sql 复制代码
CREATE TABLE test_count (
    id INT,
    name VARCHAR(50)
);

INSERT INTO test_count VALUES 
(1, 'Alice'), (2, NULL), (3, 'Bob');

SELECT COUNT(*);     -- 结果:3
SELECT COUNT(1);     -- 结果:3
SELECT COUNT(id);    -- 结果:3
SELECT COUNT(name);  -- 结果:2(NULL不计入)
  • COUNT(*)和COUNT(1)性能相同,都统计行数
  • COUNT(字段)会忽略NULL值
  • InnoDB中COUNT(*)有优化,会选择最小的索引来计数

4. LIMIT 1000000, 10为什么这么慢?

sql 复制代码
-- 这个查询需要先排序前1000010条记录,再取最后10条
SELECT * FROM users ORDER BY id LIMIT 1000000, 10;

-- 优化方法:使用子查询 + 主键
SELECT * FROM users 
WHERE id >= (SELECT id FROM users ORDER BY id LIMIT 1000000, 1)
ORDER BY id LIMIT 10;

-- 或者使用游标分页
SELECT * FROM users WHERE id > 1000000 ORDER BY id LIMIT 10;

5. 为什么InnoDB表必须有主键?

sql 复制代码
-- 创建没有主键的表
CREATE TABLE test_no_pk (
    name VARCHAR(50),
    age INT
) ENGINE=InnoDB;

-- MySQL会按以下顺序创建隐藏主键:
-- 1. 选择第一个非NULL的UNIQUE索引作为主键
-- 2. 如果没有,创建一个6字节的隐藏rowid字段作为主键

6. MySQL的隐式类型转换规则?

偏门点: 字符串和数字比较的转换规则

sql 复制代码
SELECT '123' = 123;        -- 结果:1(true)
SELECT '123abc' = 123;     -- 结果:1(true)!!!
SELECT 'abc123' = 123;     -- 结果:0(false)

-- 字符串转数字:从左开始,遇到非数字字符停止
SELECT '123.45abc' + 0;    -- 结果:123.45
SELECT 'abc123' + 0;       -- 结果:0
  • 字符串与数字比较时,字符串会转换为数字
  • 转换规则:从左开始取数字部分,遇到非数字停止

7. DELETE FROM table和TRUNCATE的隐藏区别?

sql 复制代码
-- DELETE会触发触发器,TRUNCATE不会
CREATE TRIGGER tr_delete BEFORE DELETE ON test_table
FOR EACH ROW INSERT INTO log_table VALUES(OLD.id);

DELETE FROM test_table;   
TRUNCATE test_table;       

-- AUTO_INCREMENT重置行为不同,都会清空表数据
-- DELETE后AUTO_INCREMENT值保持不变
-- TRUNCATE后AUTO_INCREMENT重置为1
相关推荐
程序新视界15 小时前
MySQL“索引失效”的隐形杀手:隐式类型转换,你了解多少?
数据库·mysql·dba
Logintern0915 小时前
windows如何设置mongodb的副本集
数据库·windows·mongodb
XYiFfang16 小时前
【MYSQL】SQL学习指南:从常见错误到高级函数与正则表达式
sql·mysql·正则表达式·regexp_like·group_concat
叫我龙翔16 小时前
【MySQL】从零开始了解数据库开发 --- 数据表的约束
android·c++·mysql·数据库开发
RestCloud17 小时前
在制造业数字化转型浪潮中,数据已成为核心生产要素。然而,系统割裂、数据滞后、开发运维成本高等问题,却像顽固的 “数据枷锁”,阻碍着企业发展。ETLCloud与
数据库·postgresql
!chen17 小时前
【Spring Boot】自定义starter
java·数据库·spring boot
流烟默17 小时前
MySQL索引调优之索引顺序必须和字段顺序一致吗?
mysql·索引调优
十碗饭吃不饱18 小时前
sql报错:java.sql.SQLSyntaxErrorException: Unknown column ‘as0‘ in ‘where clause‘
java·数据库·sql
我是Superman丶18 小时前
【优化】Mysql指定索引查询或忽略某个索引
数据库·mysql
程序定小飞18 小时前
基于springboot的在线商城系统设计与开发
java·数据库·vue.js·spring boot·后端