网站首页 > 文章精选 正文
在日常工作中,我们常用的数据库无非是Mysql、Oracle、SqlServer、DB2这几种(仅针对关系型数据库中),对于我们来说,数据库的性能优化是一个重点问题,也是很多公司面试时喜欢提及的,这里总结了一些比较常见,但又相对容易忽略的部分,供大家批判学习。
1、切勿使用select * 进行全表查询
select * 会直接查询出数据表中的全量字段数据,可能很多数据并不需要,白白浪费了数据库资源,并且select * 不会走覆盖索引,可能会出现回表操作,在单表数据量较大情况下,导致sql查询的效率低下。
2、尽量用union all 替代union
union组合查询,可以不获取几张表排重后的数据结果。
union all 是用来获取几张表的全量数据,不会排重,包含重复数据。
在union排重的过程中,需要遍历、排序和比较,耗时耗资源。所以,若非一些不可有重复数据的业务场景外,尽量选择union all。
3、小表驱动大表
何为小表驱动大表?顾名思义,两多表联合查询时,用数据量小的表去驱动数据量大的数据表,譬如:有user和order两张表,order表为100万数据量,user表有100条数据,此时想查一下有效用户下过的订单情况。
有如下两种实现方式:
这两种方式,其实使用in查询的效果更好,因为,执行顺序是先执行in中子查询,然后再执行外面的雨具,此时in中数据量少,查询速度快。
当使用exists时,会优先查询左侧的主查询,然后将查询出的结果和右边的语句进行匹配,用100万条数据与100条数据匹配结果,显然效率会查很多。
这种做一个小总结:
1:in关键字适应于左边大表,右边小表;
2:exists关键字适应于左侧小表,右边大表;
后面我们还会提及的join连接查询,也同样是遵循小表驱动大表规则。
4、用连接查询代替子查询
在Mysql中,如果想通过多张表查询数据,一般会使用子查询或者连接查询的方式进行处理(在Mysql8.0之后支持与Oracle相同的WITH AS语法进行数据分块处理 )
通过in关键字实现的子查询方式,需要先查询出内层语句的结果,作为外层语句的过滤条件使用,在这个过程中子查询会被创建为临时表,查询结束后,删除这些临时表,如果几百上千行的sql中频繁使用的话,会多一些性能损耗。
这时候可以考虑通过连接查询,但是!在《阿里巴巴开发者手册》中对于join的使用数量限制在了3个,当一段sql中频繁使用join的话,会带来索引选择的困难,曾经在工作中,使用一个数据量较大的表进行了6次的left join 最终查询耗时很久。
这里建议大家可以采用多种方式混合使用的方式,先用with as 将核心数据进行一次处理,随后在通过 join进行联接查询,汇总结果。
5、建表时选择合适字段
- 能用数字类型,就不用字符串,字符的处理要比数字慢
- 满足使用情况下,用小类型,比如bit用来存布尔值,tinyint存枚举值
- 长度固定的字符串字段,用char类型
- 长度可变字符串用varchar类型
- 金额字段用decimal,避免精度丢失
猜你喜欢
- 2025-06-13 oracle sql优化(oracle sql优化面试技巧)
- 2025-06-13 全面掌握 LINQ:方法汇总与实用技巧
- 2025-06-13 最详细的 MySQL 执行计划和索引优化!
- 2025-06-13 Redis的集合(Set):不重复的才是最好的!抽奖、共同好友就用它
- 2025-06-13 SQLite批量INSERT(sqlite文件用什么打开)
- 2025-06-13 程序员必知的10个SQL优化实用技巧,熟记后让你效率提升翻倍
- 2025-06-13 查询中,有没有可能多个索引一起用呢?
- 2025-06-13 修图app年度推荐 - iOS(修图软件iphone)
- 2025-06-13 微信生态账号体系-各ID介绍与Unionid的获取
- 2025-06-13 我试了试用 SQL查 Linux日志,好用到飞起
- 最近发表
- 标签列表
-
- newcoder (56)
- 字符串的长度是指 (45)
- drawcontours()参数说明 (60)
- unsignedshortint (59)
- postman并发请求 (47)
- python列表删除 (50)
- 左程云什么水平 (56)
- 计算机网络的拓扑结构是指() (45)
- 编程题 (64)
- postgresql默认端口 (66)
- 数据库的概念模型独立于 (48)
- 产生系统死锁的原因可能是由于 (51)
- 数据库中只存放视图的 (62)
- 在vi中退出不保存的命令是 (53)
- 哪个命令可以将普通用户转换成超级用户 (49)
- noscript标签的作用 (48)
- 联合利华网申 (49)
- swagger和postman (46)
- 结构化程序设计主要强调 (53)
- 172.1 (57)
- apipostwebsocket (47)
- 唯品会后台 (61)
- 简历助手 (56)
- offshow (61)
- mysql数据库面试题 (57)