QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2485|回复: 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
    拼多多面试问了数据库基础知识,今天分享出来. s4 U& {; M1 C3 F3 i, T$ A
      K! u# C9 x8 O: m9 L4 l8 s! _
    前言" `$ }$ v6 R% R
    # L4 o3 [4 a' b) j: @
    我是个标题党,所有文章的名字只是我的噱头,我们应该有一颗谦逊的心,所以希望大家怀着空杯心态好好学,一起进步。2 o: I* h! ?7 r( K1 K. g
    8 u& h5 g" ~& K& p) g
    数据库我想大家应该一点都不陌生吧,我想不管你写啥的,数据库就算没用过也听过了,是我们项目体系里面不可或缺的一环。
    % |; S1 R7 Z$ W+ m" e: T0 y& w0 A; f3 J3 x4 l
    问了一圈,身边朋友公司要么用自研,要么就清一色的MySQL,所以想看Oracle的朋友可能要失望了,但是不影响你了解数据库的通用知识。
    ! n! F- r1 v6 P; F
      f1 y  p4 z( e+ A正文+ t" ~4 F, c* o: a! O: p

    0 {+ U  P/ w! S+ \你知道MySQL的基本架构么?你能在纸上给我大致画出这个示意图么?( r" O( I: Y+ l/ w
    1.jpg ! g4 z4 O8 a4 A$ N1 O  T$ z
    好的那我们按照顺序了解下,连接器是啥?
    / ?. i2 ?/ {7 s+ ^我们要进行查询,第一步就是先去链接数据库,那这个时候就是连接器跟我们对接。
    3 a% o& s* x3 F4 h4 c9 w# O& N9 W! y7 m9 w  z
    他负责跟客户端建立链接、获取权限、维持和管理连接。
    ! i: c. u2 o+ }; y5 U
    + w. q8 @- B! g! Z. E' M4 O! f8 ?链接的时候会经过TCP握手,然后身份验证,然后我们输入用户名密码就好了。% m* H- F6 o- R( @& ^6 i# F

    - A% u/ b6 O1 O0 g验证ok后,我们就连上了这个MySQL服务了,但是这个时候我们处于空闲状态。5 Y+ N- @! ]( R' N* a6 \8 v
    & m( F7 Q% P0 T/ v; I
    怎么查看空闲连接列表?
    0 y8 t  s) y  M! O8 Z  Gshow processlist,下图就是我在自己的数据库表执行命令的结果,其中的Command列显示为Sleep的这一行,就表示现在系统里面有一个空闲连接。3 l; E) q" n$ ?* {8 m; d. f9 n
    2.jpg
    ; c3 `5 l) p- Q" E4 U% f这里需要注意的是,我们数据库的客户端太久没响应,连接器就会自动断开了,这个时间参数是wait_timeout控制住的,默认时长为8小时。) _1 _- ~, ?0 t4 k6 r7 l9 N( B

    ; G/ c- a5 r4 w- m! B# {断开后重连的时候会报错,如果你想再继续操作,你就需要重连了。
      n! g. D) E# g7 I
    1 b- t5 g# S; ?" g: R9 c5 l  \这个有个我看过的书本的案例:
    ( o8 L% A4 q* E7 K# T5 B, W3 ?' d7 M% |" X4 @3 L
    一个在政府里的朋友说,他们的系统很奇怪,每天早上都得重启一下应用程序,否则就提示连接数据库失败,他们都不知道该怎么办。
    $ r/ F/ g& O2 f我分析说,按照这个错误提示,应该就是连接时间过长了,断开了连接。数据库默认的超时时间是8小时,而你们平时六点下班,下班之后系统就没有人用了,等到第二天早上九点甚至十点才上班,这中间的时间已经超过10个小时了,数据库的连接肯定就会断开了。3 P0 r& c  o2 y0 G
    是的,就是超出了超时时间,然后写代码的人也没注意到这个细节,所以才会出现这个问题。
    % s+ q% {& h2 b# w: x3 W; Q0 H$ w* q
    把超时时间改得长一点,问题就解决了。! ], s: q8 j9 f8 q! c3 `( Z

    9 b: x. k7 x9 e0 a8 K这种参数其实我们平时不一定能接触到,但是真的遇到问题的时候,知道每个参数的大概用法,不至于让你变成无头苍蝇。8 {4 b9 ~8 _6 U8 G+ r6 |

    4 ~: M% |! g2 J9 ]% z4 L( _7 ]% A0 w( b那除了重新链接,还有别的方式么?因为建立链接还是比较麻烦的。: {# D% p2 y, h- t
    使用长连接。
    : y2 B; ^7 W6 X+ @$ h% B/ q
    6 `8 T% s5 {6 ^1 E  W1 V5 c5 |但是这里有个缺点,使用长连接之后,内存会飙得很快,我们知道MySQL在执行过程中临时使用的内存是管理在连接对象里面的。
    3 q  h9 @3 L  E6 N0 v, G
    ! K% a1 L- {9 D只有在链接断开的时候才能得到释放,那如果一直使用长连接,那就会导致OOM(Out Of Memory),会导致MySQL重启,在JVM里面就会导致频繁的Full GC。
    ( U* L; X( K7 ]6 Y* ~# W" F3 Y7 z% E$ M; f
    那你会怎么解决?- |6 l4 R+ U6 G
    我一般会定期断开长连接,使用一段时间后,或者程序里面判断执行过一个占用内存比较大的查询后就断开连接,需要的时候重连就好了。
    / }' r! N: s3 ^) ^' v3 u9 w% T& m# H6 x& O# N7 U) k
    还有别的方法么?你这种感觉不优雅呀小老弟。
    4 K& l9 Y3 Y5 \1 e% S. O( \执行比较大的一个查询后,执行mysql_reset_connection可以重新初始化连接资源。这个过程相比上面一种会好点,不需要重连,但是会初始化连接的状态。
    - w! v7 e' O6 H2 M/ W$ }, U# v8 [1 V) }) w6 ~. ]
    你了解MySQL的查询缓存么?, z" I8 T' d% t# o4 A" l0 ^! r7 _. A' u
    MySQL拿到一个查询请求后,会先到查询缓存看看,之前是不是执行过这条语句。
    # M, n: Y: i. P9 G0 R$ K' s4 r) T4 m) w. X" h  [9 r
    大家是不是好奇同一条语句在MySQL执行两次,第一次和后面的时间是不一样的,后者明显快一些,这就是因为缓存的存在。
    5 p+ v/ E' N' B& \! U8 V7 x% e  q7 N- j
    他跟Redis一样,只要是你之前执行过的语句,都会在内存里面用key-value形式存储着。
    % f, `$ K4 f! ~+ Y
    5 Z( Z' J- L4 K: p查询的时候就会拿着语句先去缓存中查询,如果能够命中就返回缓存的value,如果不命中就执行后面的阶段。6 G. {5 m8 d% \/ r2 r

      o, l2 m+ |9 A# a但是我还是不喜欢用缓存,因为缓存弊大于利。4 P! f7 D! K+ h: m

    . P' S1 T5 U  {% I哦?此话怎讲?% C$ T' k. C- R4 _) v  Q& ^# m) N
    缓存的失效很容易,只要对表有任何的更新,这个表的所有查询缓存就会全部被清空,就会出现缓存还没使用,就直接被清空了,或者积累了很多缓存准备用来着,但是一个更新打回原形。/ T5 s7 E1 W0 ]* T
    ( C7 l) W. \- I9 v+ T; D3 M
    这就导致查询的命中率低的可怕,只有那种只查询不更新的表适用缓存,但是这样的表往往很少存在,一般都是什么配置表之类的。
    - q4 _* O1 l" j% L$ S8 S( X' S+ H& f0 G6 f
    那我们查询的时候不想用缓存一般都是怎么操作的,或者是用缓存又怎么操作?
    4 ?7 {, u2 a) g3 N& K# d8 x可以显示调用,把query_cache_type设置成为DEMAND,这样SQL默认不适用缓存,想用缓存就用SQL_CACHE。
    & x9 `, `0 T8 ^! z' x, v+ J
    7 _& c2 _0 j0 ~& x7 i/ z5 g有个小技巧就是,我们之前开发的时候,都会去库里看看sql执行时间,但是可能是有缓存的,一般我们就在sql前面使用SQL_NO_CACHE就可以知道真正的查询时间了。
    3 H" o/ t1 K# a; F  D: y
    2 q& {$ L; x3 t, k select SQL_NO_CACHE * from B
    0 h( p" ?( a' ~7 L0 R5 F缓存在MySQL8.0之后就取消了,所以大家现在应该不需要太关注这个问题,主要是我之前用的版本都不高,所以缓存一直有,在《高性能MySQL》书中也看到了一些关于缓存的介绍,就想起来给大家也提一下了。/ R4 x4 U* M5 r

    6 C. B5 m( J4 t缓存查询完了应该做啥呢?
    7 X& `; K. v' e7 ^! I1 S, I在缓存没有命中的情况下,就开始执行语句了,你写的语句有没有语法错误,这是接下来MySQL比较关心的点。
    . U$ B- W( U" m9 H2 l0 Z- H& R+ v3 L( k
    那他会怎么做呢?会先做词法分析,你的语句有这么多单词、空格,MySQL就需要识别每个字符串所代表的是什么,是关键字,还是表名,还是列名等等。
    2 P2 i. O$ U8 ?; A! f6 i/ e+ @
    然后就开始语法分析,根据词法分析的结果,语法分析会判断你sql的对错,错了会提醒你的,并且会提示你哪里错了。
    : ^/ m6 b, R# d" ]1 I7 c8 {6 Z 3.jpg
    : }8 |! }& p& Q3 E' `  U分析没错之后就进入下一步,优化器。% E/ D( R% |% L$ j" ?
    # j4 w, n2 o7 \2 x
    主要是优化什么呢?
    1 l$ o6 ^! I# k3 j. K+ ~+ v/ r2 i' S优化就比较简单了,因为我们建立表可能会建立很多索引,优化有一步就是要确认使用哪个索引,比如使用你的主键索引,联合索引还是什么索引更好。% _5 U- |1 [$ `4 \; {5 a
    * t6 |6 [) v! X9 S
    还有就是对执行顺序进行优化,条件那么多,先查哪个表,还是先关联,会出现很多方案,最后由优化器决定选用哪种方案。
    $ y( @- s& w  p4 O  W
    & Q' c2 Y( ?2 e最后就是执行了,执行就交给执行器去做。
    $ p4 @7 P8 J1 g; D3 y6 G! f) I' x2 c4 r" e; @6 u
    第一步可能就是权限的判断,其实这里我不确定的一个点就是,我接触的公司很多都是自研的线上查询系统,我们是不能用Navicat直连线上库,只能去网页操作,那表的权限是在MySQL层做的,还是系统做的,我猜应该是系统层做的,MySQL可能默认就全开放了,只是我们 不知道ip。5 Q8 J  R' a8 ~# y" M  `* U+ F
    8 w* k& T5 ^# w3 K1 C. O8 M
    有知道的小伙伴也可以在公众号【三太子敖丙】去加我微信跟我说。
    , {. d) J+ |) T2 s4 w7 l1 X' a1 E! B0 ^4 v7 T% i
    执行的时候,就一行一行的去判断是否满足条件,有索引的执行起来可能就好点,一行行的判断就像是接口都提前在引擎定义好了,所以他比较快。
    $ ~" \! _0 \4 K8 t3 D) o  _( m6 p% t, K6 c: m
    数据库的慢日志有个rows_examined字段,扫描多少行可以看到,还有explain也可以看到执行计划,我们扫描了多少行。9 O/ A9 ]" l: J  _( S+ W1 y9 n/ {

    4 z, i3 @1 h/ d$ c+ e+ i可以小伙子,基础大致框架还是了解得很清楚的,我们下次深入了解下,索引和部分机制。; @( f! I5 d' Y) Q0 ^
    好的,我们下次见。+ V( F6 d( G& p1 q

    3 M1 @# e  s6 Z# F' ^- d' x总结
    2 J# j7 w' o8 l1 p7 G6 G
    + w+ {4 f: _+ \基本上我把MySQL的逻辑架构的东西都简单聊了一遍,当然你去自信了解的话,你会发现其实里面还有很多细节的,我只是说了一些常见的问题,这还是阿里丁奇学长的《MySQL实战》的思路。
    $ D' b( e0 S+ m2 D0 V' b9 P* X( c* \; P2 I& p3 y
    我自己在MySQL方面更多的可能就是理论知识了,还做不到深入了解的地步,大家如果有机会一定要深入的去学习一下。
    - M7 {. z% g! H( _————————————————0 P4 s2 K' `) S" k0 E4 [4 n% W
    版权声明:本文为CSDN博主「敖 丙」的原创文章,遵循 CC 4.0 BY 版权协议,转载请附上原文出处链接及本声明。3 e3 Z7 n+ x* m: K8 |$ B( i# T4 P
    原文链接:https://blog.csdn.net/qq_35190492/article/details/104203466
    . \' ^1 Y% a6 I1 m# u4 M2 \) M# n. g$ `' ?1 j
    2 n) c  M- M5 P, X% j
    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-4-14 00:09 , Processed in 0.415846 second(s), 53 queries .

    回顶部