sql语句优化面试题有哪些?sql语句优化面试题

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工具网。

推荐阅读:

java编程基础课程有哪些?初学者怎么学java?

java架构师的技术要求是什么?怎么提高java技能?

javabean组件提交表单的代码怎么写?如何处理表单数据?