QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2288|回复: 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
    拼多多面试问了数据库基础知识,今天分享出来  M+ U$ c1 z0 d- G& J3 d

    & E7 t2 O8 e# c, \/ G/ h+ X- c前言1 q( x0 \& w' i/ P- K; x! i5 |$ l

    ( O8 U# W+ \' {" H: Z7 p我是个标题党,所有文章的名字只是我的噱头,我们应该有一颗谦逊的心,所以希望大家怀着空杯心态好好学,一起进步。
    7 a8 y0 b! r- O3 A1 ^
    5 }/ d2 i% i' {% ?! d. H* X7 r/ Q数据库我想大家应该一点都不陌生吧,我想不管你写啥的,数据库就算没用过也听过了,是我们项目体系里面不可或缺的一环。% t1 \& n7 X  D+ t+ }

      a' |+ F& x' j6 a; G* ?; Z问了一圈,身边朋友公司要么用自研,要么就清一色的MySQL,所以想看Oracle的朋友可能要失望了,但是不影响你了解数据库的通用知识。
    8 A+ X! W5 R6 `5 ?; G+ X; K$ N' w' j4 Q" c
    正文& w9 I2 I  o: N; A& ~0 U
    + Q; Q! P, v1 I- m+ S
    你知道MySQL的基本架构么?你能在纸上给我大致画出这个示意图么?
    3 J7 e; K& K3 {  G( x9 X 1.jpg : x7 e4 r, v# l% J3 Q; F
    好的那我们按照顺序了解下,连接器是啥?4 d# k4 n/ N# X1 t; H
    我们要进行查询,第一步就是先去链接数据库,那这个时候就是连接器跟我们对接。
    3 s3 R- p8 w! \# @/ S6 `7 ^+ z( L5 p3 b. Y
    他负责跟客户端建立链接、获取权限、维持和管理连接。
    1 m$ V0 R5 c( W# V
    2 k/ U" H1 h3 s- r9 z链接的时候会经过TCP握手,然后身份验证,然后我们输入用户名密码就好了。, S" c5 S" W+ e1 q

    2 M6 j' j8 |3 V; i$ z验证ok后,我们就连上了这个MySQL服务了,但是这个时候我们处于空闲状态。+ B* L0 `( n7 a" D' @  _1 _

    ( x5 c' x% n" Y: j4 k$ Y怎么查看空闲连接列表?7 [0 m: ^4 C2 u' T
    show processlist,下图就是我在自己的数据库表执行命令的结果,其中的Command列显示为Sleep的这一行,就表示现在系统里面有一个空闲连接。8 e0 f' z8 F4 `7 `. s2 L9 p
    2.jpg - t2 `9 A: r3 I' k: V7 b
    这里需要注意的是,我们数据库的客户端太久没响应,连接器就会自动断开了,这个时间参数是wait_timeout控制住的,默认时长为8小时。
      [4 |# |. s8 x% h/ r- z  e( |6 q
    + f: S  B6 f% N1 x" v. z  |断开后重连的时候会报错,如果你想再继续操作,你就需要重连了。
    + `; n1 b/ {: \2 _5 C. r. U+ H" K
    : s6 g" O% {" w& g; z这个有个我看过的书本的案例:4 E: p7 D7 c" X
    6 Z! }/ P. c+ F; u! Q9 s, ^
    一个在政府里的朋友说,他们的系统很奇怪,每天早上都得重启一下应用程序,否则就提示连接数据库失败,他们都不知道该怎么办。5 V. Y- z2 r* i0 g0 o
    我分析说,按照这个错误提示,应该就是连接时间过长了,断开了连接。数据库默认的超时时间是8小时,而你们平时六点下班,下班之后系统就没有人用了,等到第二天早上九点甚至十点才上班,这中间的时间已经超过10个小时了,数据库的连接肯定就会断开了。, q7 Z* k- M. B& `# F+ j5 J
    是的,就是超出了超时时间,然后写代码的人也没注意到这个细节,所以才会出现这个问题。
    6 w5 i* P# w+ @9 b. A, C8 K1 d* E' T0 C5 \
    把超时时间改得长一点,问题就解决了。: b2 ]9 U' i; W. `( Q1 ^( N" [

    * w7 O4 n+ @+ Z" ~" P6 Q这种参数其实我们平时不一定能接触到,但是真的遇到问题的时候,知道每个参数的大概用法,不至于让你变成无头苍蝇。
    6 I% P0 B+ T7 c: ?
    0 B- v$ M" k# L4 O2 n7 v: q5 ]那除了重新链接,还有别的方式么?因为建立链接还是比较麻烦的。
    ' j1 x9 u* \9 v使用长连接。
    * O* m, U0 [$ }  z  V4 z' D
    # T9 l7 p6 w& L% @& @但是这里有个缺点,使用长连接之后,内存会飙得很快,我们知道MySQL在执行过程中临时使用的内存是管理在连接对象里面的。) }- D* E& w( w( u  I# W6 F

    3 Z$ T, W' P* B  v. R7 P' M$ P只有在链接断开的时候才能得到释放,那如果一直使用长连接,那就会导致OOM(Out Of Memory),会导致MySQL重启,在JVM里面就会导致频繁的Full GC。7 f4 [& x0 r  d

    ' ~- `* p5 a1 h那你会怎么解决?, J* i" j- e0 F. q* W0 W- e- p
    我一般会定期断开长连接,使用一段时间后,或者程序里面判断执行过一个占用内存比较大的查询后就断开连接,需要的时候重连就好了。& i" }' Q3 L9 f. [# x% e7 @4 m
    7 z9 P6 W% Z3 q5 R' ^
    还有别的方法么?你这种感觉不优雅呀小老弟。
    3 W( i* K, \' Q7 X3 p( x' Y执行比较大的一个查询后,执行mysql_reset_connection可以重新初始化连接资源。这个过程相比上面一种会好点,不需要重连,但是会初始化连接的状态。
    & ?& B; z, q! m8 y/ t  y$ T7 _. p
    7 _" e" F) V7 Z3 n你了解MySQL的查询缓存么?
    9 a7 w) [/ }3 R! L' l3 oMySQL拿到一个查询请求后,会先到查询缓存看看,之前是不是执行过这条语句。6 S4 h  d0 t. ^

    - _6 }3 K- p9 V, q大家是不是好奇同一条语句在MySQL执行两次,第一次和后面的时间是不一样的,后者明显快一些,这就是因为缓存的存在。# N# ]3 G4 `( c2 ?$ R( r

    . f! S3 z* Y( o% }" y' f+ [他跟Redis一样,只要是你之前执行过的语句,都会在内存里面用key-value形式存储着。7 b3 h$ @, b5 O# ?, j

    : K  _$ d( q: h. N" f5 C查询的时候就会拿着语句先去缓存中查询,如果能够命中就返回缓存的value,如果不命中就执行后面的阶段。- U9 G6 [" ]- d3 ]0 I( v/ N

    4 ]8 \% f# L( I" y$ o8 @4 h但是我还是不喜欢用缓存,因为缓存弊大于利。! D6 z9 x4 T8 s: n
    / k) L6 g- E" A% s
    哦?此话怎讲?
    + K3 p- a9 B' o& G$ K0 h$ u) c缓存的失效很容易,只要对表有任何的更新,这个表的所有查询缓存就会全部被清空,就会出现缓存还没使用,就直接被清空了,或者积累了很多缓存准备用来着,但是一个更新打回原形。% r/ j! Z( u% @: P
    ) Q3 c/ r! V) F" \$ O* c( c
    这就导致查询的命中率低的可怕,只有那种只查询不更新的表适用缓存,但是这样的表往往很少存在,一般都是什么配置表之类的。
    ( D, n8 z/ Q" V
    / x6 ~9 _& V* t; f1 t$ q6 b6 o, ?/ L那我们查询的时候不想用缓存一般都是怎么操作的,或者是用缓存又怎么操作?# x, {% m+ d. f
    可以显示调用,把query_cache_type设置成为DEMAND,这样SQL默认不适用缓存,想用缓存就用SQL_CACHE。# ?; I5 Y- a5 E# P
      K! {$ x3 k) ?2 }# W0 [; m
    有个小技巧就是,我们之前开发的时候,都会去库里看看sql执行时间,但是可能是有缓存的,一般我们就在sql前面使用SQL_NO_CACHE就可以知道真正的查询时间了。
    ; \6 b  t) c. V8 T  a- [  X- J9 ~
    ' Z) m* t, n& V* p6 E! ` select SQL_NO_CACHE * from B' x6 O, f4 i1 p7 H! i4 G* Q3 `4 E
    缓存在MySQL8.0之后就取消了,所以大家现在应该不需要太关注这个问题,主要是我之前用的版本都不高,所以缓存一直有,在《高性能MySQL》书中也看到了一些关于缓存的介绍,就想起来给大家也提一下了。
    : N9 @, K2 y0 r/ A" l
    & a/ Q  L" D+ l6 O2 H' a缓存查询完了应该做啥呢?) z/ P" Y+ Z2 r2 I
    在缓存没有命中的情况下,就开始执行语句了,你写的语句有没有语法错误,这是接下来MySQL比较关心的点。! m7 W, r/ d1 U2 G3 A

    * g5 H* x: N8 u8 o. ]0 R. f! |那他会怎么做呢?会先做词法分析,你的语句有这么多单词、空格,MySQL就需要识别每个字符串所代表的是什么,是关键字,还是表名,还是列名等等。& D! V" o1 X, t# ^) F
    5 q5 E" D' i& {7 D$ E5 A# i
    然后就开始语法分析,根据词法分析的结果,语法分析会判断你sql的对错,错了会提醒你的,并且会提示你哪里错了。& k: d  k3 n2 t8 k5 s
    3.jpg . l+ h% G' P0 ]7 t
    分析没错之后就进入下一步,优化器。
    1 }$ J; U8 _: V2 S
      w7 q& b, Y7 C; D4 Y& |% Q主要是优化什么呢?7 v$ W6 K" B9 a6 S' Q9 ]- M
    优化就比较简单了,因为我们建立表可能会建立很多索引,优化有一步就是要确认使用哪个索引,比如使用你的主键索引,联合索引还是什么索引更好。
    " F# z9 q) z' b4 P0 Y
    8 y% k1 i1 c& q. D% u还有就是对执行顺序进行优化,条件那么多,先查哪个表,还是先关联,会出现很多方案,最后由优化器决定选用哪种方案。
    * v5 g8 G% I! m1 ^" ?* X, Y' j# t' A) t3 Z: w9 l3 e' v
    最后就是执行了,执行就交给执行器去做。
    + M2 {/ O( n7 N3 c0 f  H
    " U1 q5 ^! m& X, Q9 v* e) _% q第一步可能就是权限的判断,其实这里我不确定的一个点就是,我接触的公司很多都是自研的线上查询系统,我们是不能用Navicat直连线上库,只能去网页操作,那表的权限是在MySQL层做的,还是系统做的,我猜应该是系统层做的,MySQL可能默认就全开放了,只是我们 不知道ip。+ Y8 C2 O2 p; n( y! F9 i% m: N

    - v4 H, I3 K6 g( c, Z有知道的小伙伴也可以在公众号【三太子敖丙】去加我微信跟我说。; T3 B: e3 n  p( E- K7 I1 ~
    ( K7 o8 o) q6 F3 I2 F! @* a/ R3 @% q
    执行的时候,就一行一行的去判断是否满足条件,有索引的执行起来可能就好点,一行行的判断就像是接口都提前在引擎定义好了,所以他比较快。1 e, E8 E3 D8 y1 G/ ]; h! x+ c$ R- y
    1 u7 l. x! R; R7 M
    数据库的慢日志有个rows_examined字段,扫描多少行可以看到,还有explain也可以看到执行计划,我们扫描了多少行。
    - H/ K) p  T  T" H5 F
    # \! V# v) |7 i6 w5 G" B可以小伙子,基础大致框架还是了解得很清楚的,我们下次深入了解下,索引和部分机制。' ]( `2 c+ L+ d# p2 c
    好的,我们下次见。, Q3 T- I, I+ t2 ?
    # F1 N* ?3 o7 K$ c; i
    总结
    2 e( r$ H& P1 Y  d2 j& s6 s$ @* [$ E. Z( D' ?. f& o8 H
    基本上我把MySQL的逻辑架构的东西都简单聊了一遍,当然你去自信了解的话,你会发现其实里面还有很多细节的,我只是说了一些常见的问题,这还是阿里丁奇学长的《MySQL实战》的思路。' K9 L0 L7 J' W# P

    " h$ H. O- m2 ?& Z# K) L# `- ]我自己在MySQL方面更多的可能就是理论知识了,还做不到深入了解的地步,大家如果有机会一定要深入的去学习一下。, c* ]# K8 G0 e& w; S% @9 M. F
    ————————————————
    + U$ G7 _9 r' A# j. [版权声明:本文为CSDN博主「敖 丙」的原创文章,遵循 CC 4.0 BY 版权协议,转载请附上原文出处链接及本声明。
    % p5 n9 `* N. r# E, X$ D3 U% f' y: q原文链接:https://blog.csdn.net/qq_35190492/article/details/104203466
    , {- n' Q. x. H) @. ^& _4 t" ]
    # B% A$ h; q' g  m, Y; H4 O1 r. C! W
    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-19 04:34 , Processed in 0.844109 second(s), 54 queries .

    回顶部