QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2527|回复: 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
    拼多多面试问了数据库基础知识,今天分享出来+ F$ t! {2 Y; a1 i8 ?
    / b" d& @5 n9 y/ T. U3 I
    前言
    3 e0 {7 S- T5 K% S4 `. C
    : W! L0 c, U2 D6 }+ u我是个标题党,所有文章的名字只是我的噱头,我们应该有一颗谦逊的心,所以希望大家怀着空杯心态好好学,一起进步。
    ; u8 k1 M3 l/ R* ?( k- L0 l4 N8 |: F9 T1 ~6 S$ @1 g
    数据库我想大家应该一点都不陌生吧,我想不管你写啥的,数据库就算没用过也听过了,是我们项目体系里面不可或缺的一环。/ k7 H: O% q% }9 s; t+ s

    3 h! D" l9 c/ Q7 m1 D. L  j问了一圈,身边朋友公司要么用自研,要么就清一色的MySQL,所以想看Oracle的朋友可能要失望了,但是不影响你了解数据库的通用知识。& `7 t  P1 {# L3 k
    * g- P+ j& G. }  q  i0 A& \# B
    正文! _4 U7 A1 k! u3 `+ P' X
    0 T% }% J6 s8 R/ J: _* B" q
    你知道MySQL的基本架构么?你能在纸上给我大致画出这个示意图么?. G' ?- Y, @. @
    1.jpg $ [: j, B: R$ m
    好的那我们按照顺序了解下,连接器是啥?
    * A. U2 K' E  J4 j# U4 @我们要进行查询,第一步就是先去链接数据库,那这个时候就是连接器跟我们对接。/ e9 b' F- O$ t
    3 H" y4 ]# y, ~: X5 \2 I
    他负责跟客户端建立链接、获取权限、维持和管理连接。6 l' w$ P& O0 r; T: B

    - d. d6 X2 c% t1 U% o1 B9 a+ _( Q链接的时候会经过TCP握手,然后身份验证,然后我们输入用户名密码就好了。. }5 ]8 s  Y2 W1 R
    & m6 k& a0 I& o3 g; X9 I7 ?
    验证ok后,我们就连上了这个MySQL服务了,但是这个时候我们处于空闲状态。
    9 _0 T* W9 H. t& u6 a) A: H- o9 H9 E/ b' V4 U% l
    怎么查看空闲连接列表?% U0 i- @, M& Q) P2 |3 b6 \# @
    show processlist,下图就是我在自己的数据库表执行命令的结果,其中的Command列显示为Sleep的这一行,就表示现在系统里面有一个空闲连接。
    . y# {1 G& j1 n+ z& w 2.jpg
    5 Y0 C: n5 d0 Q8 u! ^" |这里需要注意的是,我们数据库的客户端太久没响应,连接器就会自动断开了,这个时间参数是wait_timeout控制住的,默认时长为8小时。4 a, @3 a$ c# ?4 |/ K% W" z, U1 Z
    ; ^; m& A1 t: x2 _0 S: y! T% R5 c
    断开后重连的时候会报错,如果你想再继续操作,你就需要重连了。/ P3 L& a6 w- g7 W+ y8 _
    & x5 d% ]0 g8 A
    这个有个我看过的书本的案例:3 A& s! x: M/ i  b

    " s5 y0 [/ z' P: C& Y  A6 \% E一个在政府里的朋友说,他们的系统很奇怪,每天早上都得重启一下应用程序,否则就提示连接数据库失败,他们都不知道该怎么办。" p1 W6 ~( W; d
    我分析说,按照这个错误提示,应该就是连接时间过长了,断开了连接。数据库默认的超时时间是8小时,而你们平时六点下班,下班之后系统就没有人用了,等到第二天早上九点甚至十点才上班,这中间的时间已经超过10个小时了,数据库的连接肯定就会断开了。. u/ r: K% p' f
    是的,就是超出了超时时间,然后写代码的人也没注意到这个细节,所以才会出现这个问题。1 F! [, g' a+ P: f$ D+ W
    7 j, Y+ h  {$ c% j0 a) Z
    把超时时间改得长一点,问题就解决了。
    / b7 r7 o& I5 I. [* {4 a; D4 _; x$ I) `; X9 b+ K  H0 M# N
    这种参数其实我们平时不一定能接触到,但是真的遇到问题的时候,知道每个参数的大概用法,不至于让你变成无头苍蝇。
    6 T. N5 Y. T0 r9 T
    * U2 `7 c* d3 }那除了重新链接,还有别的方式么?因为建立链接还是比较麻烦的。
    1 C) e0 Q( p+ }; W使用长连接。3 s. ^6 I7 h& f1 U

    & V, d9 H1 `# r0 |/ I" }但是这里有个缺点,使用长连接之后,内存会飙得很快,我们知道MySQL在执行过程中临时使用的内存是管理在连接对象里面的。
    6 ]. u0 g; ^3 j8 u1 h) F( z. X
    0 A8 p) p, i2 y$ R只有在链接断开的时候才能得到释放,那如果一直使用长连接,那就会导致OOM(Out Of Memory),会导致MySQL重启,在JVM里面就会导致频繁的Full GC。
    $ {( h! Z% j, k
    : }% q* J$ A; b" a那你会怎么解决?
    0 L: p( P2 o- M, k* X: O" T. C我一般会定期断开长连接,使用一段时间后,或者程序里面判断执行过一个占用内存比较大的查询后就断开连接,需要的时候重连就好了。
    , K# \/ f6 n* W6 Y/ {3 y* ~
    $ E; ?# g4 \- m# `5 c) _! K! N还有别的方法么?你这种感觉不优雅呀小老弟。
    - r# x0 j; N7 p执行比较大的一个查询后,执行mysql_reset_connection可以重新初始化连接资源。这个过程相比上面一种会好点,不需要重连,但是会初始化连接的状态。% e2 s% a6 Z0 f4 M+ |5 Z

    : Q  W8 j' Q" ~, ]" v, S你了解MySQL的查询缓存么?
    9 n0 V7 b( S4 y8 V& F8 v# C6 \4 @8 w0 tMySQL拿到一个查询请求后,会先到查询缓存看看,之前是不是执行过这条语句。6 H* }: a3 k0 A6 S; q# s
    - F/ E: ]$ m, T2 ]" j% `
    大家是不是好奇同一条语句在MySQL执行两次,第一次和后面的时间是不一样的,后者明显快一些,这就是因为缓存的存在。
    2 I# A  U( `% c' _$ d: a  {; i# ]% D% g# \; K1 E" _
    他跟Redis一样,只要是你之前执行过的语句,都会在内存里面用key-value形式存储着。3 c) z0 \; J" f) I6 q; N

    " F) r3 @" ]5 a: L: }# @* g7 _0 ^查询的时候就会拿着语句先去缓存中查询,如果能够命中就返回缓存的value,如果不命中就执行后面的阶段。. X1 G7 B8 ]5 v7 y3 ^. K, h" w
    # S- x. k8 j1 @2 J3 |
    但是我还是不喜欢用缓存,因为缓存弊大于利。
    * {) e$ w! b  O* B" |" k( }
    ! c# M+ }  Y2 e哦?此话怎讲?
    * @1 i& W3 ~* M& p1 n$ C缓存的失效很容易,只要对表有任何的更新,这个表的所有查询缓存就会全部被清空,就会出现缓存还没使用,就直接被清空了,或者积累了很多缓存准备用来着,但是一个更新打回原形。; T- L7 Y: N: Q# }! ^' g9 \& Y

    5 d& A7 O: ~% \这就导致查询的命中率低的可怕,只有那种只查询不更新的表适用缓存,但是这样的表往往很少存在,一般都是什么配置表之类的。5 x9 i, p1 j4 n2 x5 r
    * {/ H6 B; N% u/ }1 W
    那我们查询的时候不想用缓存一般都是怎么操作的,或者是用缓存又怎么操作?
    $ e* o* T6 C7 e0 f可以显示调用,把query_cache_type设置成为DEMAND,这样SQL默认不适用缓存,想用缓存就用SQL_CACHE。$ n; T' `0 ~3 L. @. L$ G

    6 z2 e- _+ W5 n9 F+ ]' G有个小技巧就是,我们之前开发的时候,都会去库里看看sql执行时间,但是可能是有缓存的,一般我们就在sql前面使用SQL_NO_CACHE就可以知道真正的查询时间了。
    & u) e" W8 ?" H
    + t: s: {/ [  Q+ d8 B) s" E select SQL_NO_CACHE * from B* J+ p3 p0 p2 H/ M" @
    缓存在MySQL8.0之后就取消了,所以大家现在应该不需要太关注这个问题,主要是我之前用的版本都不高,所以缓存一直有,在《高性能MySQL》书中也看到了一些关于缓存的介绍,就想起来给大家也提一下了。2 Q5 n/ C; S. A& U. H) t

    " X9 m6 w+ Y" i8 w8 G缓存查询完了应该做啥呢?
    8 `( L0 o, i9 A3 Y在缓存没有命中的情况下,就开始执行语句了,你写的语句有没有语法错误,这是接下来MySQL比较关心的点。9 W/ J) S' R+ ^1 D% s9 g

    / B" w- l; z( @9 T1 J0 M那他会怎么做呢?会先做词法分析,你的语句有这么多单词、空格,MySQL就需要识别每个字符串所代表的是什么,是关键字,还是表名,还是列名等等。
    / U9 S" o6 Z: B6 I- D
    - x8 H# S% F$ J+ O$ a然后就开始语法分析,根据词法分析的结果,语法分析会判断你sql的对错,错了会提醒你的,并且会提示你哪里错了。
    ) j0 l4 V- Z( }  `: j+ f1 V 3.jpg
    + s4 k! U6 b, R) O6 U) y分析没错之后就进入下一步,优化器。
    # ^1 G3 c" N0 T1 r! h
    & M" k( T  X& u3 ~% c/ J# y主要是优化什么呢?" o9 `- G) p, R& p8 D3 e
    优化就比较简单了,因为我们建立表可能会建立很多索引,优化有一步就是要确认使用哪个索引,比如使用你的主键索引,联合索引还是什么索引更好。1 m9 S1 L- j& C% M

    : t  r& l% |* u/ `' h- E还有就是对执行顺序进行优化,条件那么多,先查哪个表,还是先关联,会出现很多方案,最后由优化器决定选用哪种方案。+ P2 }7 W% I7 [7 b: `
    : H1 ]0 C) _& g, F
    最后就是执行了,执行就交给执行器去做。
    3 N3 ~+ i! H. s- Y+ o1 m: a3 e7 c2 H9 s' m7 t7 ~& V+ p
    第一步可能就是权限的判断,其实这里我不确定的一个点就是,我接触的公司很多都是自研的线上查询系统,我们是不能用Navicat直连线上库,只能去网页操作,那表的权限是在MySQL层做的,还是系统做的,我猜应该是系统层做的,MySQL可能默认就全开放了,只是我们 不知道ip。
    5 u% s* i5 t8 i1 t/ T  M: F" s# n4 X
    有知道的小伙伴也可以在公众号【三太子敖丙】去加我微信跟我说。( \7 S! O+ ]! I& T2 q

    / @2 ]! b; v$ S/ v! M& I3 `执行的时候,就一行一行的去判断是否满足条件,有索引的执行起来可能就好点,一行行的判断就像是接口都提前在引擎定义好了,所以他比较快。
    : x3 `% y$ M. N7 A: C8 \& y- G' y" u1 Y) W3 M: @& H: z8 ]
    数据库的慢日志有个rows_examined字段,扫描多少行可以看到,还有explain也可以看到执行计划,我们扫描了多少行。
    - |! A: x3 {0 K5 J' l. u/ p9 z4 G' E% Z# d
    可以小伙子,基础大致框架还是了解得很清楚的,我们下次深入了解下,索引和部分机制。% v: o9 g4 T& K& u/ I3 h
    好的,我们下次见。  \  A4 V3 G- [( t- r: g
    3 m0 i, e" ]3 j, ]
    总结" r: e- U! o7 W
    , Z: S- |4 F" r8 ]* s) X
    基本上我把MySQL的逻辑架构的东西都简单聊了一遍,当然你去自信了解的话,你会发现其实里面还有很多细节的,我只是说了一些常见的问题,这还是阿里丁奇学长的《MySQL实战》的思路。4 j- ?' I  S1 V- z
    5 Z5 o) h- M" R$ E5 j- R4 ^7 q
    我自己在MySQL方面更多的可能就是理论知识了,还做不到深入了解的地步,大家如果有机会一定要深入的去学习一下。
    ; }; B8 r* ?# U  |" ?————————————————
    ( O/ g" w3 a/ Q5 j& r; z版权声明:本文为CSDN博主「敖 丙」的原创文章,遵循 CC 4.0 BY 版权协议,转载请附上原文出处链接及本声明。
    4 Q2 U4 T6 e4 K, k5 Y) g$ B  a原文链接:https://blog.csdn.net/qq_35190492/article/details/104203466
    & r" c  @* h, |. t! c" f5 }( i( j5 h2 Y
    7 k1 O2 z9 I/ C
    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, 2026-6-14 19:55 , Processed in 0.431888 second(s), 54 queries .

    回顶部