QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2528|回复: 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
    拼多多面试问了数据库基础知识,今天分享出来
    & p( W5 J" W6 J8 J$ Q5 b! T: u$ N2 E1 o, P# O. ]
    前言
    9 ]) J4 l# g% a0 M8 n
    0 d! T9 [6 s  W" n4 O我是个标题党,所有文章的名字只是我的噱头,我们应该有一颗谦逊的心,所以希望大家怀着空杯心态好好学,一起进步。
    9 E- c! P0 q' f8 a+ F- y& G: y
    & |! P7 g/ p' B2 N3 i: m数据库我想大家应该一点都不陌生吧,我想不管你写啥的,数据库就算没用过也听过了,是我们项目体系里面不可或缺的一环。- r. d6 A+ n, g. M

    9 A/ }6 S4 }( ~3 q+ S/ y问了一圈,身边朋友公司要么用自研,要么就清一色的MySQL,所以想看Oracle的朋友可能要失望了,但是不影响你了解数据库的通用知识。
      z7 Y: Q8 I3 F  \; F2 S
    ( n8 N) e, T7 k9 C/ r9 @: R正文
    - N; ]2 s' Q& {3 \- |, ]
    5 Y4 L8 W* H9 P: [' ^你知道MySQL的基本架构么?你能在纸上给我大致画出这个示意图么?
    ! R8 B) ]" J6 Y: U 1.jpg
    # x) E. z/ Z+ U好的那我们按照顺序了解下,连接器是啥?8 l9 e9 t$ e9 @1 y
    我们要进行查询,第一步就是先去链接数据库,那这个时候就是连接器跟我们对接。
    / q/ j0 }/ s6 a6 U1 U% B3 Y; ?& `+ c! E8 `
    他负责跟客户端建立链接、获取权限、维持和管理连接。( h9 W  I/ L. m7 y
    " r/ _- R( _: |# d9 e& F/ K
    链接的时候会经过TCP握手,然后身份验证,然后我们输入用户名密码就好了。4 L6 H5 y: M( T" r7 D, @5 S
    . p3 @9 w. w3 F! b. s" F% o4 ]
    验证ok后,我们就连上了这个MySQL服务了,但是这个时候我们处于空闲状态。
    * t1 _( K7 k( D. l2 v
    ( S  y% z( c6 R0 q" t, k怎么查看空闲连接列表?" P4 M# V+ ^/ b, }. y5 u- w; |' y' m" V
    show processlist,下图就是我在自己的数据库表执行命令的结果,其中的Command列显示为Sleep的这一行,就表示现在系统里面有一个空闲连接。, @+ o! B. E( C3 {1 H' Q
    2.jpg , ]; l) S/ T2 Q; w
    这里需要注意的是,我们数据库的客户端太久没响应,连接器就会自动断开了,这个时间参数是wait_timeout控制住的,默认时长为8小时。
    , X4 s( {  ], ]0 B- f
    - `8 i% ?1 A# V5 I6 [. r断开后重连的时候会报错,如果你想再继续操作,你就需要重连了。
    ! N4 @5 o3 u8 J
    + q" J; b5 q* k. m+ h这个有个我看过的书本的案例:+ w, \# M8 l% W
    + G% E8 l% j0 c8 g
    一个在政府里的朋友说,他们的系统很奇怪,每天早上都得重启一下应用程序,否则就提示连接数据库失败,他们都不知道该怎么办。* W- e6 X( U/ V8 n9 K5 j
    我分析说,按照这个错误提示,应该就是连接时间过长了,断开了连接。数据库默认的超时时间是8小时,而你们平时六点下班,下班之后系统就没有人用了,等到第二天早上九点甚至十点才上班,这中间的时间已经超过10个小时了,数据库的连接肯定就会断开了。2 b- p8 X2 |% S  d* l3 |
    是的,就是超出了超时时间,然后写代码的人也没注意到这个细节,所以才会出现这个问题。- p+ X. m) I3 ?% j% d2 n" N

    . [! c& }9 l( m; _把超时时间改得长一点,问题就解决了。% V. O& e  F: n3 {) H6 ^
      W) K2 p+ L; e( x4 v
    这种参数其实我们平时不一定能接触到,但是真的遇到问题的时候,知道每个参数的大概用法,不至于让你变成无头苍蝇。9 U3 U& c+ K' o5 r
    4 v  V5 e: D% J! `
    那除了重新链接,还有别的方式么?因为建立链接还是比较麻烦的。
    0 T. y/ j1 q* q6 T使用长连接。
    9 {  q. x, W9 n! H4 a6 \) c9 v2 y6 v+ j0 }. h, e: T
    但是这里有个缺点,使用长连接之后,内存会飙得很快,我们知道MySQL在执行过程中临时使用的内存是管理在连接对象里面的。( w2 d7 |9 G2 u, _  C4 F

    1 B4 m/ C1 E) H$ @; s- i1 ]只有在链接断开的时候才能得到释放,那如果一直使用长连接,那就会导致OOM(Out Of Memory),会导致MySQL重启,在JVM里面就会导致频繁的Full GC。0 X$ P' f' A& r7 Y5 m# n4 I
    / ?. s1 e* K8 h, }; R$ h
    那你会怎么解决?
    + ?+ C' M  y) x3 i- h% }. ?我一般会定期断开长连接,使用一段时间后,或者程序里面判断执行过一个占用内存比较大的查询后就断开连接,需要的时候重连就好了。
    / m# Q/ n7 s: e* u' Z5 T  ~  N( ?% y) f( U9 }
    还有别的方法么?你这种感觉不优雅呀小老弟。4 q8 K5 Z3 x, v% z5 m) T! `6 Y) e
    执行比较大的一个查询后,执行mysql_reset_connection可以重新初始化连接资源。这个过程相比上面一种会好点,不需要重连,但是会初始化连接的状态。) j( j0 ]0 U& D5 j7 P

    ) q' ~6 N2 }7 q% I; V你了解MySQL的查询缓存么?8 V( G; u% V3 D- a
    MySQL拿到一个查询请求后,会先到查询缓存看看,之前是不是执行过这条语句。
    # ^) O* f& I* c
    5 H, B# T  M0 r& a大家是不是好奇同一条语句在MySQL执行两次,第一次和后面的时间是不一样的,后者明显快一些,这就是因为缓存的存在。/ q, j/ E$ v3 `! s) e- p& F. f
    , l8 ~3 E( h4 v# X. Q6 K* c5 ^) h3 A
    他跟Redis一样,只要是你之前执行过的语句,都会在内存里面用key-value形式存储着。" {( j: n  r, F
    8 Q  q0 ?7 d6 S' }$ E# L
    查询的时候就会拿着语句先去缓存中查询,如果能够命中就返回缓存的value,如果不命中就执行后面的阶段。3 P$ n) h. \$ C, w7 B$ |. S" t$ x
    3 O- c. c, P' e6 X# B
    但是我还是不喜欢用缓存,因为缓存弊大于利。( X4 h- G8 {/ A

    8 i+ i- q# }0 a! `3 I6 {哦?此话怎讲?
    " o( n" Q6 w8 X/ j% j2 n* E+ o缓存的失效很容易,只要对表有任何的更新,这个表的所有查询缓存就会全部被清空,就会出现缓存还没使用,就直接被清空了,或者积累了很多缓存准备用来着,但是一个更新打回原形。/ h& U1 w7 L! D( j2 m
    ! ?" c, [- c0 a
    这就导致查询的命中率低的可怕,只有那种只查询不更新的表适用缓存,但是这样的表往往很少存在,一般都是什么配置表之类的。
    $ M& f* Z! ?3 B2 R- M9 W
    7 D7 P1 R) D# g# Y# [; I2 d那我们查询的时候不想用缓存一般都是怎么操作的,或者是用缓存又怎么操作?
    ! ?; b; s9 Q. J$ s) z, t可以显示调用,把query_cache_type设置成为DEMAND,这样SQL默认不适用缓存,想用缓存就用SQL_CACHE。
      b0 x2 g' ~. t+ B3 h, B
    / ]7 J+ P4 P# Z+ i2 y" F/ [/ R有个小技巧就是,我们之前开发的时候,都会去库里看看sql执行时间,但是可能是有缓存的,一般我们就在sql前面使用SQL_NO_CACHE就可以知道真正的查询时间了。/ J1 `5 u( h: B% q

    % L( ^( v1 N- Y$ a' ?: u select SQL_NO_CACHE * from B$ _! l+ M" Z1 A. S- O0 X% R
    缓存在MySQL8.0之后就取消了,所以大家现在应该不需要太关注这个问题,主要是我之前用的版本都不高,所以缓存一直有,在《高性能MySQL》书中也看到了一些关于缓存的介绍,就想起来给大家也提一下了。
    ) l/ N' \; N$ l: ^) X( W" D2 C; S1 p7 @& Q
    缓存查询完了应该做啥呢?+ m2 L* O7 z3 w4 r* ^2 a
    在缓存没有命中的情况下,就开始执行语句了,你写的语句有没有语法错误,这是接下来MySQL比较关心的点。
      T3 p  t' I6 m' W
    , R, B/ w: c0 D/ c/ f1 o那他会怎么做呢?会先做词法分析,你的语句有这么多单词、空格,MySQL就需要识别每个字符串所代表的是什么,是关键字,还是表名,还是列名等等。% X& @. R" a$ U- T

    ' y& n6 b+ X+ A# l  Q# S/ v1 f* C然后就开始语法分析,根据词法分析的结果,语法分析会判断你sql的对错,错了会提醒你的,并且会提示你哪里错了。
    9 P2 B4 @6 r4 s 3.jpg ) `5 N8 ~% L# k# X, ?/ V
    分析没错之后就进入下一步,优化器。+ ]3 A2 n/ h( Z9 v: H
    + N# Y+ a0 U! `- ]) D
    主要是优化什么呢?
    7 v7 \& o- ~) Q/ H% G优化就比较简单了,因为我们建立表可能会建立很多索引,优化有一步就是要确认使用哪个索引,比如使用你的主键索引,联合索引还是什么索引更好。* X" a& Y- m6 `1 z/ j
    * R7 _! F9 p8 E& V$ P# A
    还有就是对执行顺序进行优化,条件那么多,先查哪个表,还是先关联,会出现很多方案,最后由优化器决定选用哪种方案。: d6 W& G! @( z0 }+ D4 l4 f

    ( u2 [" O1 r! n+ U最后就是执行了,执行就交给执行器去做。; T3 o& d5 ^! c

    & T0 [6 H* x! y+ e: Z: \( w第一步可能就是权限的判断,其实这里我不确定的一个点就是,我接触的公司很多都是自研的线上查询系统,我们是不能用Navicat直连线上库,只能去网页操作,那表的权限是在MySQL层做的,还是系统做的,我猜应该是系统层做的,MySQL可能默认就全开放了,只是我们 不知道ip。$ M* g4 K( Z- c( q' g

    ! }" d! T/ B  a* x2 m2 j- H/ |有知道的小伙伴也可以在公众号【三太子敖丙】去加我微信跟我说。' ~0 i* D9 s2 T6 k; z" X9 ^

    4 U' U! a) n4 f; Y% G执行的时候,就一行一行的去判断是否满足条件,有索引的执行起来可能就好点,一行行的判断就像是接口都提前在引擎定义好了,所以他比较快。* w7 H/ p6 L3 I/ l( E  R! F

    7 S2 j6 ]6 |* F. K# ^数据库的慢日志有个rows_examined字段,扫描多少行可以看到,还有explain也可以看到执行计划,我们扫描了多少行。1 q* [& _# k5 w+ S( L$ x0 N/ |$ V' w
    + S3 K. l0 F) p6 F8 h' {$ |
    可以小伙子,基础大致框架还是了解得很清楚的,我们下次深入了解下,索引和部分机制。' C8 R; I% M! C# G% ~7 e" c: j
    好的,我们下次见。) h0 S& c# j& ?  a  C
    " e& u# }; W4 a) n. Y0 Z. r
    总结0 D4 f; p. K6 a9 n1 C* i* o

    " h; [( U. ], |基本上我把MySQL的逻辑架构的东西都简单聊了一遍,当然你去自信了解的话,你会发现其实里面还有很多细节的,我只是说了一些常见的问题,这还是阿里丁奇学长的《MySQL实战》的思路。
    9 \% ]. z' O' m- L) Y! @+ [# ?! ]
    + ^! w/ }; u: ]& {" y我自己在MySQL方面更多的可能就是理论知识了,还做不到深入了解的地步,大家如果有机会一定要深入的去学习一下。
    # w- r# W- {: u; C* d1 n2 n————————————————
    % Y$ c. U, |) G6 N' {0 M8 k' a版权声明:本文为CSDN博主「敖 丙」的原创文章,遵循 CC 4.0 BY 版权协议,转载请附上原文出处链接及本声明。: M1 c' g# @4 V2 Y% B4 }6 g- J
    原文链接:https://blog.csdn.net/qq_35190492/article/details/104203466! q6 i- O7 G& `. o( U. `( x

      V9 X& b/ ~- k4 a) {6 D% h! l  C% M6 c2 N- X# e' I- }2 K! M
    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-15 00:16 , Processed in 0.413621 second(s), 53 queries .

    回顶部