秋招面试常见问题--数据库

1.sql优化?

为什么要进行sql优化

慢SQL消耗了70%~90%的数据库CPU资源;

SQL语句独立于程序设计逻辑,相对于对程序源代码的优化,对SQL语句的优化在时间成本和风险上的代价都很低;

SQL语句可以有不同的写法;

如何进行sql优化

1.1 不使用子查询

1.2 避免函数索引

1.3 用IN来替换OR

1.4 LIKE双百分号无法使用到索引

1.5 读取适当的记录LIMIT M,N

1.6 避免数据类型不一致

1.7 分组统计可以禁止排序

1.8 避免随机取记录

1.9 禁止不必要的ORDER BY排序

1.10 批量INSERT插入

2. 索引的原理?

https://blog.csdn.net/suifeng3051/article/details/52669644

这篇博文较好的解释了索引

3.事务?

数据库事务(Database Transaction) ,是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行。 事务处理可以确保除非事务性单元内的所有操作都成功完成,否则不会永久更新面向数据的资源。通过将一组相关操作组合为一个要么全部成功要么全部失败的单元,可以简化错误恢复并使应用程序更加可靠。一个逻辑工作单元要成为事务,必须满足所谓的ACID(原子性、一致性、隔离性和持久性)属性。事务是数据库运行中的逻辑工作单位,由DBMS中的事务管理子系统负责事务的处理。

猜你喜欢

转载自blog.csdn.net/changengchu3961/article/details/80954543