SQL 是用于访问和处理数据库的标准的计算机语言,也是在面试java岗位中必考的知识点之一,那么下面我们就给大家分享一些sql语句优化面试题,给大家提高过关的机率!
一、SQL标准定义的四个隔离级别是什么?
read uncommited :读到未提交数据
read committed:脏读,不可重复读
repeatable read:可重读
serializable :串行事物
二、ql优化您们是怎么做的?
首先开启数据库慢查询日志,定位到查询效率比较低的sql , 找出对应的sql语句并进行分析
1.表设计是否规范,是否符合三范式的标准
(1)第一范式:保证原子性(不可拆分)
(2)第二范式:每张表都有主键
(3)第三范式(每一列都有主键相关)
2.查看数据表中是否存在大量的冗余字段,字段数据类型是否合理
3.尽可能的使用varchar代替char 建表数据类型,能用数值的绝对不用字符存储
4.尽量避免null值,使用默认值替代空值,数值型可以使用0,字符型可以使用空字符串
查看sql语句是否规范:
(1)避免使用关键字:or ,in,not in ,!=,<>,避免使用select *
(2)尽量避免子查询,大部分子查询都可以连接查询
(3)用到or的地方可以使用union去代替实现
(4)用到in的地方可以使用exists去代替
分析sql的索引是否可以用上:
(1) explain查询sql的执行计划,重点关注的几个列就是,type是不是全表扫描
(2)看一下索引是否能够用的上,主要看key使用的是哪个索引
(3)看一下rows扫描行数是不是很大
三、SQL有哪些分类?
DDL—数据定义语言(Create,Alter,Drop,DECLARE)
DML—数据操纵语言(Select,Delete,Update,Insert)
DCL—数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK)
这些sql语句优化面试题大家一定要在掌握,掌握好这些可以帮助你们增加面试通关机会哦!最后大家如果想要了解更多java面试题知识,敬请关注奇Q工具网。
推荐阅读: