QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2276|回复: 0
打印 上一主题 下一主题

[参考文献] 拼多多面试问了数据库基础知识,今天分享出来

[复制链接]
字体大小: 正常 放大
杨利霞        

5273

主题

82

听众

17万

积分

  • TA的每日心情
    开心
    2021-8-11 17:59
  • 签到天数: 17 天

    [LV.4]偶尔看看III

    网络挑战赛参赛者

    网络挑战赛参赛者

    自我介绍
    本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。

    群组2018美赛大象算法课程

    群组2018美赛护航培训课程

    群组2019年 数学中国站长建

    群组2019年数据分析师课程

    群组2018年大象老师国赛优

    跳转到指定楼层
    1#
    发表于 2020-4-28 15:19 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    拼多多面试问了数据库基础知识,今天分享出来
    / M8 m5 l7 c  c! L; V# L1 ^
    4 s' h; k& Q! A3 W前言9 K2 R. J+ [2 P- t4 u
    7 t8 }# b+ ?& A- M+ q+ J
    我是个标题党,所有文章的名字只是我的噱头,我们应该有一颗谦逊的心,所以希望大家怀着空杯心态好好学,一起进步。( c3 P8 h- P% o0 @% F3 `7 L

    # e+ I4 w+ O- j  X0 V4 P# D' u# `: y数据库我想大家应该一点都不陌生吧,我想不管你写啥的,数据库就算没用过也听过了,是我们项目体系里面不可或缺的一环。& i  u& T+ O' k1 S8 R
    : P, j3 i5 G; C
    问了一圈,身边朋友公司要么用自研,要么就清一色的MySQL,所以想看Oracle的朋友可能要失望了,但是不影响你了解数据库的通用知识。
    : K& V$ o! q! [! W4 g
    1 ?* }' B0 ]- F, d* f4 h' [/ j正文8 q0 X! G2 R! K# i: H

    ! D2 e$ R/ q% f' v你知道MySQL的基本架构么?你能在纸上给我大致画出这个示意图么?
    ' d1 _0 ^) d" k) r4 @3 _) j 1.jpg
    9 F% j- U" J0 l4 t& f0 t好的那我们按照顺序了解下,连接器是啥?! u1 E8 `& Y- N. D
    我们要进行查询,第一步就是先去链接数据库,那这个时候就是连接器跟我们对接。
    ) @! T% y9 q) C: Z2 M
    ' V; s; C- ~# w& K他负责跟客户端建立链接、获取权限、维持和管理连接。
    / z# W, A, A* V8 \6 B/ P+ ]7 X% \2 r8 s9 S- |
    链接的时候会经过TCP握手,然后身份验证,然后我们输入用户名密码就好了。
    6 N. K" K7 A8 ^; J, `. n
    3 ]+ ]0 S, `' ^1 G! {验证ok后,我们就连上了这个MySQL服务了,但是这个时候我们处于空闲状态。) M5 t1 J9 Z# u& m7 Z( }
    , ~- S5 @* b, {& m7 b2 V3 m
    怎么查看空闲连接列表?8 a1 ]9 t$ V; A4 E# e/ T
    show processlist,下图就是我在自己的数据库表执行命令的结果,其中的Command列显示为Sleep的这一行,就表示现在系统里面有一个空闲连接。, s' y- f, q* o2 j5 _
    2.jpg
    1 U$ \( N  W9 v0 {这里需要注意的是,我们数据库的客户端太久没响应,连接器就会自动断开了,这个时间参数是wait_timeout控制住的,默认时长为8小时。0 Y# }3 |; s9 [; s4 Z: D
    , l2 n) @* \+ U- B6 ^
    断开后重连的时候会报错,如果你想再继续操作,你就需要重连了。
    . @! e. ^$ a' m3 i( v" u9 d2 ^4 i' W7 U
    这个有个我看过的书本的案例:; ^! |4 H: F) L* _! _/ z' [

    % W2 I  ]) B0 p+ d% w6 o一个在政府里的朋友说,他们的系统很奇怪,每天早上都得重启一下应用程序,否则就提示连接数据库失败,他们都不知道该怎么办。4 @7 ~7 T" s) }+ p& [4 O) H9 h
    我分析说,按照这个错误提示,应该就是连接时间过长了,断开了连接。数据库默认的超时时间是8小时,而你们平时六点下班,下班之后系统就没有人用了,等到第二天早上九点甚至十点才上班,这中间的时间已经超过10个小时了,数据库的连接肯定就会断开了。
    ' T' N% C7 F; d9 {* d/ h7 f" z2 C8 q: s是的,就是超出了超时时间,然后写代码的人也没注意到这个细节,所以才会出现这个问题。
    2 ]6 l( n8 ~1 P4 V
    6 S) k1 a' m; Z) d# d, A把超时时间改得长一点,问题就解决了。  m9 C! ]; Z2 L, S

    # c! q3 p% E. \/ S) v/ o" F+ j这种参数其实我们平时不一定能接触到,但是真的遇到问题的时候,知道每个参数的大概用法,不至于让你变成无头苍蝇。7 e4 X: _5 \" ?

    + e7 \+ x$ M, p7 B9 H$ t那除了重新链接,还有别的方式么?因为建立链接还是比较麻烦的。5 N1 v' F- h0 O& |
    使用长连接。
    # N( q1 _9 `" I- B
    9 b5 S3 m* U, ]0 D9 o但是这里有个缺点,使用长连接之后,内存会飙得很快,我们知道MySQL在执行过程中临时使用的内存是管理在连接对象里面的。$ K$ Z) s; p2 ]! c
    9 F* c" x/ n. t# g6 V
    只有在链接断开的时候才能得到释放,那如果一直使用长连接,那就会导致OOM(Out Of Memory),会导致MySQL重启,在JVM里面就会导致频繁的Full GC。
    ' l; O8 w0 M8 E, E5 v) I4 ~
    ; C3 s4 x/ X) M+ F那你会怎么解决?( ^% j! ]4 F# h$ d3 x
    我一般会定期断开长连接,使用一段时间后,或者程序里面判断执行过一个占用内存比较大的查询后就断开连接,需要的时候重连就好了。
    $ P( Q/ v. d) x" {# z) s+ U4 R, p% G& f( ], }
    还有别的方法么?你这种感觉不优雅呀小老弟。
    & C" X0 m1 f0 U0 P: n) a执行比较大的一个查询后,执行mysql_reset_connection可以重新初始化连接资源。这个过程相比上面一种会好点,不需要重连,但是会初始化连接的状态。2 G# z7 u6 P' b. e3 L$ n
    / \# J9 Z% j/ X% L) N$ L( A
    你了解MySQL的查询缓存么?3 B4 c6 c" \2 T  E& F
    MySQL拿到一个查询请求后,会先到查询缓存看看,之前是不是执行过这条语句。
    7 w: M0 i1 Z, |- E$ m- n/ S( }& g) F, g4 c' V' |
    大家是不是好奇同一条语句在MySQL执行两次,第一次和后面的时间是不一样的,后者明显快一些,这就是因为缓存的存在。
    ) G% I5 x$ m3 {- G- }5 Q" X6 M- g5 R# h/ j4 H$ R- B* ~
    他跟Redis一样,只要是你之前执行过的语句,都会在内存里面用key-value形式存储着。6 U. \1 @& D$ \

    5 v  y8 t  c9 S查询的时候就会拿着语句先去缓存中查询,如果能够命中就返回缓存的value,如果不命中就执行后面的阶段。
    ( t" Z* ~4 J& Z7 o" b4 k/ W" @% W; u0 Z5 a
    但是我还是不喜欢用缓存,因为缓存弊大于利。9 ^6 H  ?' y, @' C3 @
    6 S( c4 P* i) J+ ]+ {/ R6 ]/ ?
    哦?此话怎讲?
    , `- H9 ]: \; P* h; P6 J3 ]缓存的失效很容易,只要对表有任何的更新,这个表的所有查询缓存就会全部被清空,就会出现缓存还没使用,就直接被清空了,或者积累了很多缓存准备用来着,但是一个更新打回原形。
    ) Y/ ~" D$ u. B# X" W
    ' }- \- o& r" q* y这就导致查询的命中率低的可怕,只有那种只查询不更新的表适用缓存,但是这样的表往往很少存在,一般都是什么配置表之类的。
    & m! ^3 \! P) Y- y9 t( u/ f  o& L
    . [$ R0 H* b, ^3 a. @8 h) `那我们查询的时候不想用缓存一般都是怎么操作的,或者是用缓存又怎么操作?1 m. O6 [: y1 D+ p) F0 u! |+ Q0 h* `
    可以显示调用,把query_cache_type设置成为DEMAND,这样SQL默认不适用缓存,想用缓存就用SQL_CACHE。
    " p" v% k* ]% [0 H9 A3 }7 p  D0 D8 k) Q
    有个小技巧就是,我们之前开发的时候,都会去库里看看sql执行时间,但是可能是有缓存的,一般我们就在sql前面使用SQL_NO_CACHE就可以知道真正的查询时间了。
    ) [7 e5 {4 \& N5 {
    # N) K$ W' {. R: c# ~! d select SQL_NO_CACHE * from B
      e+ m9 h% A& u0 r8 ^& b2 D缓存在MySQL8.0之后就取消了,所以大家现在应该不需要太关注这个问题,主要是我之前用的版本都不高,所以缓存一直有,在《高性能MySQL》书中也看到了一些关于缓存的介绍,就想起来给大家也提一下了。0 M. @( q" H2 U2 Y" T
    0 z  k2 v, @- M9 U4 {( J+ `
    缓存查询完了应该做啥呢?
    1 Z7 O, _) q* Y9 l5 E6 N; J在缓存没有命中的情况下,就开始执行语句了,你写的语句有没有语法错误,这是接下来MySQL比较关心的点。; _$ ?8 N/ e* G* y' M5 Z- f

    6 ]3 K0 d. b# s" t/ F+ A9 t1 m那他会怎么做呢?会先做词法分析,你的语句有这么多单词、空格,MySQL就需要识别每个字符串所代表的是什么,是关键字,还是表名,还是列名等等。
    7 I! d5 y" Q' h& O0 A! _! L8 }2 Q) g9 M/ h, ^4 ]
    然后就开始语法分析,根据词法分析的结果,语法分析会判断你sql的对错,错了会提醒你的,并且会提示你哪里错了。
    9 ]2 d7 t! a( \ 3.jpg
    * @; k$ X& Q+ ?/ |0 t分析没错之后就进入下一步,优化器。3 [* J, @2 B# O( ~: J
      Z& z( S5 Q: V3 G. O0 ]
    主要是优化什么呢?. x( J" @: A" X) q/ W2 g; A
    优化就比较简单了,因为我们建立表可能会建立很多索引,优化有一步就是要确认使用哪个索引,比如使用你的主键索引,联合索引还是什么索引更好。4 b, I3 `  e( b

    % Y3 j7 j( Y  z7 w, a8 f还有就是对执行顺序进行优化,条件那么多,先查哪个表,还是先关联,会出现很多方案,最后由优化器决定选用哪种方案。
    ( X+ g& v3 N7 L" K( V6 [1 @( N+ L
    最后就是执行了,执行就交给执行器去做。6 a! G( v- `& O+ k( p6 B
    # `( B: H# E1 C+ Q! k
    第一步可能就是权限的判断,其实这里我不确定的一个点就是,我接触的公司很多都是自研的线上查询系统,我们是不能用Navicat直连线上库,只能去网页操作,那表的权限是在MySQL层做的,还是系统做的,我猜应该是系统层做的,MySQL可能默认就全开放了,只是我们 不知道ip。
    % x9 i$ B$ ?1 C0 M8 k# @1 A# s6 G1 {5 H+ X# j8 J% e
    有知道的小伙伴也可以在公众号【三太子敖丙】去加我微信跟我说。# H" X8 |& h& s" Q, K2 }5 e

    - n" ]4 ]; r- v( L执行的时候,就一行一行的去判断是否满足条件,有索引的执行起来可能就好点,一行行的判断就像是接口都提前在引擎定义好了,所以他比较快。
    5 C: ^  M% o% o$ D# ]) q8 m+ f2 x( ]$ k# A& d5 N; a
    数据库的慢日志有个rows_examined字段,扫描多少行可以看到,还有explain也可以看到执行计划,我们扫描了多少行。
    " x; m- f/ N, U0 G) g
    0 a, g5 Y: m* P8 F' C/ @可以小伙子,基础大致框架还是了解得很清楚的,我们下次深入了解下,索引和部分机制。
    ) i  _7 |, L+ H3 [: F好的,我们下次见。
    ) r# t1 [4 n: A
    8 M$ }6 _3 ?( y! B4 @9 V总结0 I/ f6 F6 \! H& A' H; l
    5 ^/ H0 x6 E  w, N
    基本上我把MySQL的逻辑架构的东西都简单聊了一遍,当然你去自信了解的话,你会发现其实里面还有很多细节的,我只是说了一些常见的问题,这还是阿里丁奇学长的《MySQL实战》的思路。
    , h; f! N2 [+ [! T, z. l+ n  v( e' u! ?" Y
    我自己在MySQL方面更多的可能就是理论知识了,还做不到深入了解的地步,大家如果有机会一定要深入的去学习一下。4 p0 L) d, @9 U& M& g! K
    ————————————————  ^0 g' ~( Z' b1 c- f
    版权声明:本文为CSDN博主「敖 丙」的原创文章,遵循 CC 4.0 BY 版权协议,转载请附上原文出处链接及本声明。! E7 y  P! i7 ]; r( o) g
    原文链接:https://blog.csdn.net/qq_35190492/article/details/104203466
    % b0 E# s$ T& }; c
    # J- Z' `; [' E5 U$ {( Q$ \& M8 ?4 a: d7 x" s6 F( a* o* N% Q
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-11-16 06:02 , Processed in 0.628945 second(s), 54 queries .

    回顶部