71. varchar(50)中50的涵义
字段最多存放 50 个字符 如 varchar(50) 和 varchar(200) 存储 "jay" 字符串所占空间是一样的,后者在排序时会消耗更多内存
72. mysql中int(20)和char(20)以及varchar(20)的区别
-
int(20) 表示字段是int类型,显示长度是 20
-
char(20)表示字段是固定长度字符串,长度为 20
-
varchar(20) 表示字段是可变长度字符串,长度为 20
73. drop、delete与truncate的区别

74. UNION与UNION ALL的区别?
-
Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;
-
Union All:对两个结果集进行并集操作,包括重复行,不进行排序;
-
UNION的效率高于 UNION ALL
75. SQL的生命周期?
-
服务器与数据库建立连接
-
数据库进程拿到请求sql
-
解析并生成执行计划,执行
-
读取数据到内存,并进行逻辑处理
-
通过步骤一的连接,发送结果到客户端
-
关掉连接,释放资源
76. 一条Sql的执行顺序?

77. 列值为NULL时,查询是否会用到索引?
列值为NULL也是可以走索引的 计划对列进行索引,应尽量避免把它设置为可空,因为这会让 MySQL 难以优化引用了可空列的查询,同时增加了引擎的复杂度
78. 关心过业务系统里面的sql耗时吗?统计过慢查询吗?对慢查询都怎么优化过?
-
我们平时写Sql时,都要养成用explain分析的习惯。
-
慢查询的统计,运维会定期统计给我们
优化慢查询:
-
分析语句,是否加载了不必要的字段/数据。
-
分析SQl执行句话,是否命中索引等。
-
如果SQL很复杂,优化SQL结构
-
如果表数据量太大,考虑分表
79. 主键使用自增ID还是UUID,为什么?
如果是单机的话,选择自增ID;如果是分布式系统,优先考虑UUID吧,但还是最好自己公司有一套分布式唯一ID生产方案吧。
-
自增ID:数据存储空间小,查询效率高。但是如果数据量过大,会超出自增长的值范围,多库合并,也有可能有问题。
-
uuid:适合大量数据的插入和更新操作,但是它无序的,插入数据效率慢,占用空间大。
80. mysql自增主键用完了怎么办?
自增主键一般用int类型,一般达不到最大值,可以考虑提前分库分表的。
自增ID用完后 一直都是最大值 如果标识了主键 则主键冲突
652

被折叠的 条评论
为什么被折叠?



