网上查的面试题
一. 基础部分
- drop、truncate、 delete区别
- truncate 和 delete只删除数据,不删除表结构 ,drop删除表结构,并且释放所占的空间。
- 删除数据的速度,drop> truncate > delete
- delete属于DML语言,需要事务管理,commit之后才能生效。drop和truncate属于DDL语言,操作立刻生效,不可回滚。
- 使用场合:
当你不再需要该表时, 用 drop;
当你仍要保留该表,但要删除所有记录时, 用 truncate;
当你要删除部分记录时(always with a where clause), 用 delete.
- 数据库三范式是什么?
- union和union all有什么不同?
- char、varchar2、varchar有什么区别?
- 合并查询有哪些?
- SQL语句执行顺序
- null的含义
- MySQL、SqlServer、oracle写出字符存储、字符串转时间
- update语句可以修改结果集中的数据吗?
- B树和B+树的区别
- 你建过索引吗? 建索引的原则
- 索引的类型, 如主键索引
- 查看SQL执行计划
- 有十万条数据, 写SQL语句查询其中某字段较大值的几条数据
- 子查询与关联查询的区别
- MySQL InnoDB、Mysaim的特点?
- 乐观锁和悲观锁的区别??
- 行锁和表锁的区别?
- 数据库隔离级别是什么?有什么作用?
- MySQL主备同步的基本原理。
- 如何优化数据库性能(索引、分库分表、批量操作、分页算法、升级硬盘SSD、业务优化、主从部署)
- SQL什么情况下不会使用索引(不包含,不等于,函数)
一般在什么字段上建索引(过滤数据最多的字段) - MySQL,B+索引实现,行锁实现,SQL优化
- 如何解决高并发减库存问题:https://www.cnblogs.com/wuyifu/p/4065664.html
- 数据库事务的几种粒度
二. 实战部分
- 数据库三范式,根据秒杀场景设计数据表
- 数据库的主从复制
- 死锁怎么解决
- mysql并发情况下怎么解决(通过事务、隔离级别、锁)
- 触发器的作用?
- 什么是存储过程?用什么来调用?
- 存储过程的优缺点?
- 存储过程与函数的区别
- 索引的作用?和它的优点缺点是什么?
- 什么样的字段适合建索引
- 索引类型有哪些?
- 什么是事务?什么是锁?
- 什么叫视图?游标是什么?
- 视图的优缺点
- 列举几种表连接方式,有什么区别?
- 主键和外键的区别?
- 在数据库中查询语句速度很慢,如何优化?
- 数据库三范式是什么?
- Varchar2和varchar有什么区别?
- Oracle和Mysql的区别?
- order by与group by的区别
三. 高级进阶
- 请解释关系型数据库概念及主要特点?
- 请说出关系型数据库的典型产品、特点及应用场景?
- 请解释非关系型数据库概念及主要特点?
- 请说出非关系型数据库的典型产品、特点及应用场景?
- 请详细描述 SQL 语句分类及对应代表性关键字。
- 请详细描述 char(4)和 varchar(4)的差别。
- 如何授权 oldboy 用户从 172.16.1.0/24 访问数据库。
- 什么是 MySQL 多实例,如何配置 MySQL 多实例?
- 如何加强 MySQL 安全,请给出可行的具体措施?
- delete 和 truncate 删除数据的区别?
- MySQL Sleep 线程过多如何解决?
- sort_buffer_size 参数作用?如何在线修改生效?
- 如何在线正确清理 MySQL binlog?
- Binlog 工作模式有哪些?各什么特点,企业如何选择?
- 误操作执行了一个 drop 库 SQL 语句,如何完整恢复?
- mysqldump 备份使用了-A -B 参数,如何实现恢复单表?
- 详述 MySQL 主从复制原理及配置主从的完整步骤。
- 如何开启从库的 binlog 功能?
- MySQL 如何实现双向互为主从复制,并说明应用场景?
- MySQL 如何实现级联同步,并说明应用场景?
- MySQL 主从复制故障如何解决?
- 如何监控主从复制是否故障?
- MySQL 数据库如何实现读写分离?
- 生产一主多从从库宕机,如何手工恢复?