QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2482|回复: 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& X# h* f5 A( C) q( ?

    " h8 M8 O+ y$ q! X5 @/ l前言+ C2 |4 Z+ [" U/ l
    ! C$ e% S2 x, ]5 D) ?
    我是个标题党,所有文章的名字只是我的噱头,我们应该有一颗谦逊的心,所以希望大家怀着空杯心态好好学,一起进步。/ x% i( k1 F$ q+ b1 y- L
    $ u. {& r7 |  H5 Q
    数据库我想大家应该一点都不陌生吧,我想不管你写啥的,数据库就算没用过也听过了,是我们项目体系里面不可或缺的一环。: Q3 O$ |4 i% q8 }9 U  R
    1 A+ t& f5 ~& S3 H* _4 I' h9 h
    问了一圈,身边朋友公司要么用自研,要么就清一色的MySQL,所以想看Oracle的朋友可能要失望了,但是不影响你了解数据库的通用知识。
    ' A0 U  X' J) c: |; Z. W4 Z* {9 N
    正文$ j( X5 m+ ?0 f" u9 C

    : Q/ V# Q8 d- x8 ?( c你知道MySQL的基本架构么?你能在纸上给我大致画出这个示意图么?
    0 Z3 n* @/ ~: ]$ e2 t; l 1.jpg * A( q( q5 V( g9 ?, }
    好的那我们按照顺序了解下,连接器是啥?
    " b- V, y( G1 x0 C4 i8 e) l+ v我们要进行查询,第一步就是先去链接数据库,那这个时候就是连接器跟我们对接。
    9 q8 V& r$ ?) v$ E. s9 ~) W8 w0 n- y' E0 r& f
    他负责跟客户端建立链接、获取权限、维持和管理连接。
    2 h, D$ l, ?" I' W" _1 ]/ m# z! f; n
    链接的时候会经过TCP握手,然后身份验证,然后我们输入用户名密码就好了。* I# N$ U, ~' u! Z  c

    6 M' |' r/ k: o" [( R' k验证ok后,我们就连上了这个MySQL服务了,但是这个时候我们处于空闲状态。
    $ D+ N  @5 }7 b, T4 F  _8 o' i! Y4 }. a
    怎么查看空闲连接列表?
    ' I5 K  d- T. r& sshow processlist,下图就是我在自己的数据库表执行命令的结果,其中的Command列显示为Sleep的这一行,就表示现在系统里面有一个空闲连接。: e0 n. r% u$ _+ `/ g7 ]
    2.jpg & Q6 I5 x. S+ {) o% I0 c
    这里需要注意的是,我们数据库的客户端太久没响应,连接器就会自动断开了,这个时间参数是wait_timeout控制住的,默认时长为8小时。
    7 L, B- `4 P3 X7 L  q* N8 r2 b5 L9 k/ V( d2 L; A! {. M+ Y
    断开后重连的时候会报错,如果你想再继续操作,你就需要重连了。) A  S' A+ H- L. e: `' J1 @
    : A, H! L0 M# g+ U4 t" V* b+ j
    这个有个我看过的书本的案例:
    ! W6 e  q2 ^" F7 d" X5 L$ A- H' q2 \% F+ y2 B. b" M7 Z) {! z/ ]$ `) Y, w
    一个在政府里的朋友说,他们的系统很奇怪,每天早上都得重启一下应用程序,否则就提示连接数据库失败,他们都不知道该怎么办。1 `0 N* n  F  X* f$ Z. M
    我分析说,按照这个错误提示,应该就是连接时间过长了,断开了连接。数据库默认的超时时间是8小时,而你们平时六点下班,下班之后系统就没有人用了,等到第二天早上九点甚至十点才上班,这中间的时间已经超过10个小时了,数据库的连接肯定就会断开了。  u; H/ @' g' v2 ?, C* Q! i, G
    是的,就是超出了超时时间,然后写代码的人也没注意到这个细节,所以才会出现这个问题。4 s5 k( F# s1 r- N6 l

    0 `8 m! y/ W4 d" M把超时时间改得长一点,问题就解决了。
    1 u; s( H: b/ w  X$ }+ f# a; G$ y4 b& P$ x% d' k+ J2 D
    这种参数其实我们平时不一定能接触到,但是真的遇到问题的时候,知道每个参数的大概用法,不至于让你变成无头苍蝇。
    % F) O, A; o$ ^1 r( T. e3 a% S3 H' m5 |1 R$ Q$ V
    那除了重新链接,还有别的方式么?因为建立链接还是比较麻烦的。4 |& q. Q$ g8 T4 `1 I* h& d
    使用长连接。
    / c1 D0 w' ^- x$ J
      N: T2 d6 |+ Z4 D/ j) m$ w但是这里有个缺点,使用长连接之后,内存会飙得很快,我们知道MySQL在执行过程中临时使用的内存是管理在连接对象里面的。& Z  f4 ^, v4 y$ x/ \9 j

    " v" m2 v$ x0 y# \& U% J只有在链接断开的时候才能得到释放,那如果一直使用长连接,那就会导致OOM(Out Of Memory),会导致MySQL重启,在JVM里面就会导致频繁的Full GC。
    + V1 m4 `1 s; z" W
    2 N0 u5 h5 q( Y: a' K# W/ h  K& ?$ i那你会怎么解决?
    $ n0 V+ C3 B# w( x+ {( i0 ]我一般会定期断开长连接,使用一段时间后,或者程序里面判断执行过一个占用内存比较大的查询后就断开连接,需要的时候重连就好了。( h% O. j+ `  Y/ k3 v

      M$ Y& p. o' p2 x4 T3 x5 i还有别的方法么?你这种感觉不优雅呀小老弟。
    8 o  s" x* K: \& x执行比较大的一个查询后,执行mysql_reset_connection可以重新初始化连接资源。这个过程相比上面一种会好点,不需要重连,但是会初始化连接的状态。4 p6 Y8 d- s0 k' }7 Q8 T
    6 l5 @( m5 c2 z; j+ q" e
    你了解MySQL的查询缓存么?3 s( @. g5 Y/ u; e( K
    MySQL拿到一个查询请求后,会先到查询缓存看看,之前是不是执行过这条语句。
    $ y! {/ w( f/ ~8 _: ~1 M# a% I
    ; p# T8 X# ~* w- t$ v大家是不是好奇同一条语句在MySQL执行两次,第一次和后面的时间是不一样的,后者明显快一些,这就是因为缓存的存在。1 f1 O8 o/ V7 W7 ]4 |9 p# |

    1 U) \5 U+ r/ O2 h他跟Redis一样,只要是你之前执行过的语句,都会在内存里面用key-value形式存储着。" l  S- P5 M* K7 m' L2 V& s
    8 a  h. y$ c. o
    查询的时候就会拿着语句先去缓存中查询,如果能够命中就返回缓存的value,如果不命中就执行后面的阶段。
    6 K+ A( ]8 V' G' Z# W2 Z) o( q" [
    但是我还是不喜欢用缓存,因为缓存弊大于利。( p" s- V" V* J: x- V1 c

    5 p2 {# K0 c- V- n9 z哦?此话怎讲?3 `* F0 a; F/ W6 C( |5 p& j$ w2 P
    缓存的失效很容易,只要对表有任何的更新,这个表的所有查询缓存就会全部被清空,就会出现缓存还没使用,就直接被清空了,或者积累了很多缓存准备用来着,但是一个更新打回原形。/ U: {  u; G" P9 t, S
    5 J6 |) r  n% N2 g
    这就导致查询的命中率低的可怕,只有那种只查询不更新的表适用缓存,但是这样的表往往很少存在,一般都是什么配置表之类的。
    , m6 v/ Y1 D9 Q9 H  Y# d+ ]4 Q4 t) t& \2 b8 l8 h: T9 g
    那我们查询的时候不想用缓存一般都是怎么操作的,或者是用缓存又怎么操作?
    + V8 z# S6 D7 X# p/ ?可以显示调用,把query_cache_type设置成为DEMAND,这样SQL默认不适用缓存,想用缓存就用SQL_CACHE。/ ~, d: ?0 {3 g' u) \0 g
    & ^: M  R& H' E- Z4 a8 s. o
    有个小技巧就是,我们之前开发的时候,都会去库里看看sql执行时间,但是可能是有缓存的,一般我们就在sql前面使用SQL_NO_CACHE就可以知道真正的查询时间了。* y. S+ D4 F' F' A* Z, x" }
    , |1 V- |) v6 j3 x
    select SQL_NO_CACHE * from B% m" d- c. U% Y( U" J6 E
    缓存在MySQL8.0之后就取消了,所以大家现在应该不需要太关注这个问题,主要是我之前用的版本都不高,所以缓存一直有,在《高性能MySQL》书中也看到了一些关于缓存的介绍,就想起来给大家也提一下了。3 g0 d# w' \* b; U; U# J3 D

    . O3 N2 Q, p) i* e1 z" z& R缓存查询完了应该做啥呢?
    - @. a8 q; m4 s" m. Z+ K/ ]在缓存没有命中的情况下,就开始执行语句了,你写的语句有没有语法错误,这是接下来MySQL比较关心的点。
    0 E9 P% D8 ~/ h8 S% w$ I& u. S  f9 ^8 S% m4 R0 I
    那他会怎么做呢?会先做词法分析,你的语句有这么多单词、空格,MySQL就需要识别每个字符串所代表的是什么,是关键字,还是表名,还是列名等等。
    & a' r- U: h- i% l. v- n! A6 A' [' M8 D9 B
    然后就开始语法分析,根据词法分析的结果,语法分析会判断你sql的对错,错了会提醒你的,并且会提示你哪里错了。. g; c, Y$ g: J; r
    3.jpg
    + e6 [& S2 E6 I$ o. r分析没错之后就进入下一步,优化器。! z. E# f' _9 |" O# {

    ( }0 l# Q# A7 k1 n主要是优化什么呢?
    3 h$ Y8 L6 j, i, X3 ^优化就比较简单了,因为我们建立表可能会建立很多索引,优化有一步就是要确认使用哪个索引,比如使用你的主键索引,联合索引还是什么索引更好。0 `2 J0 y. }# h0 G( \3 u
    - [( {' Z% h+ i  v; n
    还有就是对执行顺序进行优化,条件那么多,先查哪个表,还是先关联,会出现很多方案,最后由优化器决定选用哪种方案。, Y: t' w( p: ?! l* \/ k1 P
    & S( J8 c1 ?4 c7 L
    最后就是执行了,执行就交给执行器去做。
    $ V4 t2 [, \# M7 f  @$ i: c$ M" d
    3 V9 S: d* R0 I/ m8 E第一步可能就是权限的判断,其实这里我不确定的一个点就是,我接触的公司很多都是自研的线上查询系统,我们是不能用Navicat直连线上库,只能去网页操作,那表的权限是在MySQL层做的,还是系统做的,我猜应该是系统层做的,MySQL可能默认就全开放了,只是我们 不知道ip。8 z; }: l5 t' j; B1 ^* D' y& \- Y
    2 W* u& v9 N; R
    有知道的小伙伴也可以在公众号【三太子敖丙】去加我微信跟我说。, L' ]3 M9 v/ [) o0 G
    / D0 {7 b% _. Y: }2 C
    执行的时候,就一行一行的去判断是否满足条件,有索引的执行起来可能就好点,一行行的判断就像是接口都提前在引擎定义好了,所以他比较快。! h% h( M4 S* w0 C$ @$ `4 A
    ! G# w, A" Z# Q* C5 r. h! i" F2 V
    数据库的慢日志有个rows_examined字段,扫描多少行可以看到,还有explain也可以看到执行计划,我们扫描了多少行。
    * N. Q' u+ g2 U9 C, h" f( u2 J0 k9 i, ^+ U, Q
    可以小伙子,基础大致框架还是了解得很清楚的,我们下次深入了解下,索引和部分机制。
    ! P! D# H4 M: w好的,我们下次见。
    : v+ r1 `$ |8 h/ ]/ }' a+ x, w$ Y' @* O* V: T4 x# d
    总结
    + Q# v# ]8 }5 f/ Z* u3 k& o$ w3 k: @7 c+ R
    基本上我把MySQL的逻辑架构的东西都简单聊了一遍,当然你去自信了解的话,你会发现其实里面还有很多细节的,我只是说了一些常见的问题,这还是阿里丁奇学长的《MySQL实战》的思路。
    4 h: ?; |  ?# I, [1 N3 N7 w9 @6 ?8 p9 e+ L& _
    我自己在MySQL方面更多的可能就是理论知识了,还做不到深入了解的地步,大家如果有机会一定要深入的去学习一下。
    , \$ _2 @5 ?7 A* [" I————————————————/ c/ ?! T3 G, C3 {) y
    版权声明:本文为CSDN博主「敖 丙」的原创文章,遵循 CC 4.0 BY 版权协议,转载请附上原文出处链接及本声明。
    , ]/ Q) j. h" p原文链接:https://blog.csdn.net/qq_35190492/article/details/1042034665 n! M/ Q% e- n- K7 q; l
    6 e1 Q, y9 Y( S4 Z% A; M8 ]6 j# ~

    $ j4 s' n9 L- b+ d) 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-12 12:21 , Processed in 0.425690 second(s), 54 queries .

    回顶部