QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2526|回复: 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
    拼多多面试问了数据库基础知识,今天分享出来! E' _0 s$ D2 U: x
    ! i$ ~6 U; [' V) O2 G# d
    前言
    ) ?! P$ t$ R) r. R% j! S! L/ b3 u- r* y# O0 B' p
    我是个标题党,所有文章的名字只是我的噱头,我们应该有一颗谦逊的心,所以希望大家怀着空杯心态好好学,一起进步。4 w) y  v' E3 h4 i" y6 u
    ' y$ ?# n  K' ~4 Z& w) E
    数据库我想大家应该一点都不陌生吧,我想不管你写啥的,数据库就算没用过也听过了,是我们项目体系里面不可或缺的一环。
    # {0 \. J! u1 m, o, L/ W3 s. W
    ' e1 I2 p  P- J2 ~问了一圈,身边朋友公司要么用自研,要么就清一色的MySQL,所以想看Oracle的朋友可能要失望了,但是不影响你了解数据库的通用知识。
    8 `8 T( e9 X1 T
    8 m$ i0 W% {3 X' ?正文( z( w- B/ p4 H' z
    2 I1 h/ d1 b$ Z: s) i
    你知道MySQL的基本架构么?你能在纸上给我大致画出这个示意图么?" I" N8 D  S' K! h) F: A6 R( a! c, Y
    1.jpg ) U/ Q4 P& i1 d0 I
    好的那我们按照顺序了解下,连接器是啥?: B2 |' K1 ~# F$ ^8 W) B" F& o
    我们要进行查询,第一步就是先去链接数据库,那这个时候就是连接器跟我们对接。
    3 b2 g! t6 K  X* K' z% I
    1 c( R  @4 B+ i. q9 R) f4 y他负责跟客户端建立链接、获取权限、维持和管理连接。- C. t( S# E2 y* a
    % Z% P: W0 ?  Z
    链接的时候会经过TCP握手,然后身份验证,然后我们输入用户名密码就好了。
    : u! ]3 v: J7 v4 T8 p# Z  i6 G  l) b9 N& V
    验证ok后,我们就连上了这个MySQL服务了,但是这个时候我们处于空闲状态。. f% q2 J0 a, w/ |& o$ G

      l; q! C2 v$ l3 o4 L) U( U5 U怎么查看空闲连接列表?+ V; e3 Q3 i- F4 h
    show processlist,下图就是我在自己的数据库表执行命令的结果,其中的Command列显示为Sleep的这一行,就表示现在系统里面有一个空闲连接。/ Z6 Z% z: I5 q4 [" j% G3 a' J! f
    2.jpg 6 T2 I) u& m5 R3 R
    这里需要注意的是,我们数据库的客户端太久没响应,连接器就会自动断开了,这个时间参数是wait_timeout控制住的,默认时长为8小时。8 z  M8 ?! I+ c( U5 ]
    1 I9 K3 w1 i% i' r% J# G; ^9 ?3 o: t
    断开后重连的时候会报错,如果你想再继续操作,你就需要重连了。
    , n- |% h8 _2 }& Z
    3 |( I: s7 V6 _0 V! Y这个有个我看过的书本的案例:
    7 `1 R# Z, F: K" q+ z* F; [' n, _
    一个在政府里的朋友说,他们的系统很奇怪,每天早上都得重启一下应用程序,否则就提示连接数据库失败,他们都不知道该怎么办。& X% W( [( ~' Y; G6 W
    我分析说,按照这个错误提示,应该就是连接时间过长了,断开了连接。数据库默认的超时时间是8小时,而你们平时六点下班,下班之后系统就没有人用了,等到第二天早上九点甚至十点才上班,这中间的时间已经超过10个小时了,数据库的连接肯定就会断开了。5 e8 k4 O1 w, `7 a% J; [
    是的,就是超出了超时时间,然后写代码的人也没注意到这个细节,所以才会出现这个问题。
    7 t6 ~# M7 C. m- p4 \' r) K. q) ^0 ~: L' f, y% X
    把超时时间改得长一点,问题就解决了。
    ; b  D: @& ~2 T* u) U1 d. F/ J* n) @: E0 P! l/ s% \. a1 E
    这种参数其实我们平时不一定能接触到,但是真的遇到问题的时候,知道每个参数的大概用法,不至于让你变成无头苍蝇。
    8 J2 K# A4 z0 \; E: @/ W& ?, ]* {0 R+ ?2 W, K. n. r, d
    那除了重新链接,还有别的方式么?因为建立链接还是比较麻烦的。
    " K1 G9 J  ^. d/ e0 l使用长连接。
    % [; m& [: E; Y, w& \0 o
    # T0 \9 w5 F- `- X但是这里有个缺点,使用长连接之后,内存会飙得很快,我们知道MySQL在执行过程中临时使用的内存是管理在连接对象里面的。# C5 W9 H0 D2 C( H& T+ n6 b0 q! ?0 J

    / a' E, _+ B& X& `只有在链接断开的时候才能得到释放,那如果一直使用长连接,那就会导致OOM(Out Of Memory),会导致MySQL重启,在JVM里面就会导致频繁的Full GC。: d8 B# I* a% M: ]
    ' U" m0 I* {. {5 @0 |
    那你会怎么解决?
    % m2 o: Y- ]4 Q7 N& o% a我一般会定期断开长连接,使用一段时间后,或者程序里面判断执行过一个占用内存比较大的查询后就断开连接,需要的时候重连就好了。
    8 {' X. q/ `/ e9 _& t! G- m9 I: b  `* n2 L
    还有别的方法么?你这种感觉不优雅呀小老弟。& W% J2 M2 e: y7 s& ]+ }3 U% Z$ K; u
    执行比较大的一个查询后,执行mysql_reset_connection可以重新初始化连接资源。这个过程相比上面一种会好点,不需要重连,但是会初始化连接的状态。$ w( d* {; x2 j1 p

    " o$ X2 l5 f4 c4 V5 L0 z- {你了解MySQL的查询缓存么?
    1 w6 m- u" a. _* V3 [" [* a2 jMySQL拿到一个查询请求后,会先到查询缓存看看,之前是不是执行过这条语句。
    5 V* Z7 i5 \! |* i- P0 B
    $ E7 N' q: }% |大家是不是好奇同一条语句在MySQL执行两次,第一次和后面的时间是不一样的,后者明显快一些,这就是因为缓存的存在。
    $ H) u4 b. W$ d0 b8 v" B$ d
    " c6 B: _" @. P; _他跟Redis一样,只要是你之前执行过的语句,都会在内存里面用key-value形式存储着。
    & E# z6 F$ Y+ N% a" d( s% r1 K% ?1 V( v9 P
    查询的时候就会拿着语句先去缓存中查询,如果能够命中就返回缓存的value,如果不命中就执行后面的阶段。
    # Q. v- c- m* K* b7 N6 k  R0 I) A% |% \/ Q$ u* t9 n* x
    但是我还是不喜欢用缓存,因为缓存弊大于利。
    0 y, J# s. Q. r( l9 H2 i4 v- u- p
    7 r3 n- y# A6 y/ J! _5 Z) b5 N1 \哦?此话怎讲?9 \3 D! K. _( Q
    缓存的失效很容易,只要对表有任何的更新,这个表的所有查询缓存就会全部被清空,就会出现缓存还没使用,就直接被清空了,或者积累了很多缓存准备用来着,但是一个更新打回原形。
    4 D7 I6 V# S9 [* `8 ?: y
    0 u& K1 a3 N0 }. ]  E5 U# ^, F这就导致查询的命中率低的可怕,只有那种只查询不更新的表适用缓存,但是这样的表往往很少存在,一般都是什么配置表之类的。
    6 \1 L& Y" m1 D9 ^- z* F7 U" j" g4 o5 U) D. v3 V! h& N; i
    那我们查询的时候不想用缓存一般都是怎么操作的,或者是用缓存又怎么操作?  R: q: b2 z  Y) P- m" ~* G
    可以显示调用,把query_cache_type设置成为DEMAND,这样SQL默认不适用缓存,想用缓存就用SQL_CACHE。( T8 y: s% ]4 |) o
    & U  L$ C' P$ z3 n
    有个小技巧就是,我们之前开发的时候,都会去库里看看sql执行时间,但是可能是有缓存的,一般我们就在sql前面使用SQL_NO_CACHE就可以知道真正的查询时间了。
    6 a3 D+ J1 V3 _6 Z" q8 L* K% j' T& p- Y4 l
    select SQL_NO_CACHE * from B
    ! V; Z8 F1 P" h+ x! W8 [缓存在MySQL8.0之后就取消了,所以大家现在应该不需要太关注这个问题,主要是我之前用的版本都不高,所以缓存一直有,在《高性能MySQL》书中也看到了一些关于缓存的介绍,就想起来给大家也提一下了。
    $ l: p) k5 m5 H  v4 u9 ]8 r# Z# Y1 D1 r8 ?
    缓存查询完了应该做啥呢?1 G& Y" U. T0 `* ^& c4 M
    在缓存没有命中的情况下,就开始执行语句了,你写的语句有没有语法错误,这是接下来MySQL比较关心的点。
    1 X6 D' `* n+ F) q
    ( L5 `# x" u; I8 y, q- ~那他会怎么做呢?会先做词法分析,你的语句有这么多单词、空格,MySQL就需要识别每个字符串所代表的是什么,是关键字,还是表名,还是列名等等。
    & b& k* H; t* G/ j! m! X6 S4 b: |+ P# F( M
    然后就开始语法分析,根据词法分析的结果,语法分析会判断你sql的对错,错了会提醒你的,并且会提示你哪里错了。
    ' b! _" g& E, T+ A* t5 G 3.jpg ! `" h7 f# t5 t  m. L
    分析没错之后就进入下一步,优化器。8 _8 J7 o8 y+ e4 s
      `7 o, f3 w- g# Q3 t
    主要是优化什么呢?
    5 q4 a& O6 Q( S优化就比较简单了,因为我们建立表可能会建立很多索引,优化有一步就是要确认使用哪个索引,比如使用你的主键索引,联合索引还是什么索引更好。0 Y# O; g; k# J- Q* j* a4 e% @

    % ^6 u( b2 u9 l4 B3 H还有就是对执行顺序进行优化,条件那么多,先查哪个表,还是先关联,会出现很多方案,最后由优化器决定选用哪种方案。
    9 l7 \7 F9 U: U- P3 @- E! ?" k4 x2 n' m/ G' e
    最后就是执行了,执行就交给执行器去做。
    1 @9 x9 f$ f7 ^5 n. ]
    / h. ^: k0 V6 W第一步可能就是权限的判断,其实这里我不确定的一个点就是,我接触的公司很多都是自研的线上查询系统,我们是不能用Navicat直连线上库,只能去网页操作,那表的权限是在MySQL层做的,还是系统做的,我猜应该是系统层做的,MySQL可能默认就全开放了,只是我们 不知道ip。
    7 z" Z, K+ V0 n9 |7 S0 n8 F: o8 V0 x- r3 S, R* D. x# ^$ K
    有知道的小伙伴也可以在公众号【三太子敖丙】去加我微信跟我说。
    # k0 w7 h/ t) J
    " s5 O' V  ^; W- B+ y8 q执行的时候,就一行一行的去判断是否满足条件,有索引的执行起来可能就好点,一行行的判断就像是接口都提前在引擎定义好了,所以他比较快。
    # F' g, N& D0 ?2 j- e
    ! t/ I# I) i, w6 L# u3 \数据库的慢日志有个rows_examined字段,扫描多少行可以看到,还有explain也可以看到执行计划,我们扫描了多少行。6 Z# [, `6 M1 n

    - K9 v" P# T5 b5 u. a) s6 j% `可以小伙子,基础大致框架还是了解得很清楚的,我们下次深入了解下,索引和部分机制。
    / R% C: s' e+ T/ m+ K/ y9 L; k8 }# A好的,我们下次见。
    ( w+ U% t5 P- j/ D, r- d* R* z5 B! q) l
    总结
    7 ~9 I2 H/ R  v
    ; r6 ]1 i) h3 l6 m基本上我把MySQL的逻辑架构的东西都简单聊了一遍,当然你去自信了解的话,你会发现其实里面还有很多细节的,我只是说了一些常见的问题,这还是阿里丁奇学长的《MySQL实战》的思路。* U$ U' i1 A2 L; E0 a: i
    4 S) }% C3 x* p
    我自己在MySQL方面更多的可能就是理论知识了,还做不到深入了解的地步,大家如果有机会一定要深入的去学习一下。
    " L$ ^7 q1 |% s6 D: E————————————————
    / V* Q8 L* K0 a. `% Q版权声明:本文为CSDN博主「敖 丙」的原创文章,遵循 CC 4.0 BY 版权协议,转载请附上原文出处链接及本声明。' m, Y2 h6 b7 J( v
    原文链接:https://blog.csdn.net/qq_35190492/article/details/104203466
    $ B* Q# t" Q" S" J. A3 Z$ G$ b& E7 |1 ?7 U5 ~0 \

    " b# M2 ^& c! r: e
    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:36 , Processed in 0.429055 second(s), 55 queries .

    回顶部