【java面试day19】mysql-优化

文章目录

    • 问题
      • [💬 Question 1](#💬 Question 1)
      • [💬 Question 2](#💬 Question 2)
      • [💬 Question 3](#💬 Question 3)
    • 相关知识

问题

💬 Question 1

Q :你有那些sql优化的经验呢?
A:sql的优化在项目中还是比较常见的,通常我们会从几个方面进行考虑,比如建表的时候,索引的创建和使用,sql语句的编写等等,对于读多写少的场景可以考虑主从复制、读写分离来提升性能,而对于数据量较大的情况可以通过分库分表来进行优化。

💬 Question 2

Q :在创建表的时候你们是如何优化的呢?
A:这个我们主要参考的是阿里巴巴开发手册《嵩山版》。在定义字段时,会结合实际业务场景选择合适的数据类型。比如数值型字段,会根据取值范围选择 tinyint、int 或 bigint;而对于字符串字段,如果是固定长度的就用 char,可变长度的用 varchar,如果内容较大则会考虑使用 text。

💬 Question 3

Q :你平时对sql做了那些优化呢?
A:这个优化的话还是有很多的,比如在查询时要明确指定字段,避免使用 SELECT *;在编写 SQL 时要注意避免写法导致索引失效。在做聚合查询时,能用 UNION ALL 就不要用 UNION,因为 UNION 会多一次去重操作,效率较低。在关联查询时,尽量使用 INNER JOIN,少用 LEFT JOIN 和 RIGHT JOIN,如果必须使用,也要尽量让小表去驱动大表,以减少数据扫描量。

相关知识

mysql相关知识

相关推荐
张np3 分钟前
java基础-ArrayList
java·开发语言
Swizard3 分钟前
别让 AI 假装在工作:Android "Vibe Coding" 的生存指南
android·java·vibe coding
菜鸟小九8 分钟前
mysql运维(日志)
运维·数据库·mysql
over69710 分钟前
深入理解 JavaScript 原型链与继承机制:从 instanceof 到多种继承模式
前端·javascript·面试
BBB努力学习程序设计11 分钟前
Java集合框架:管理数据的"超级工具箱"
java
库库林_沙琪马26 分钟前
1、Hi~ SpringBoot
java·spring boot·后端
不会编程的小寒27 分钟前
C / C++ 面试题
java·开发语言
zwm_yy27 分钟前
mysql主从主备回顾
运维·mysql·adb
BBB努力学习程序设计29 分钟前
Java输入输出:让程序能与世界“对话”
java
电饭叔31 分钟前
《python语言程序设计》2018版--第8章14题利用字符串输入作为一个信用卡号之一(Luhn算法解释)
android·java·python