QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2517|回复: 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
    拼多多面试问了数据库基础知识,今天分享出来! |% S) y. G: l- T

    # w2 e) w5 {  V: L前言1 Z8 \) _5 R+ |2 u: M/ A  i
    $ i$ I8 q( |9 N5 k
    我是个标题党,所有文章的名字只是我的噱头,我们应该有一颗谦逊的心,所以希望大家怀着空杯心态好好学,一起进步。
    ; k& }5 y7 y8 W1 K, `. L0 ~* `" m& {2 M0 u
    数据库我想大家应该一点都不陌生吧,我想不管你写啥的,数据库就算没用过也听过了,是我们项目体系里面不可或缺的一环。
    3 Q: n. k  V( O% L$ F0 I- G" }9 d
    . [6 z  }# |; Z& X) \问了一圈,身边朋友公司要么用自研,要么就清一色的MySQL,所以想看Oracle的朋友可能要失望了,但是不影响你了解数据库的通用知识。
    3 U; I& O3 Q( j' E* {1 G2 U& ?) O! X, J% d
    正文4 G! _3 y; F) Y& ?6 B
    ' X# T. j9 V, ^3 C9 o4 o
    你知道MySQL的基本架构么?你能在纸上给我大致画出这个示意图么?$ Z" e( k4 M( A) _/ j3 V
    1.jpg
      p, O2 o6 d: k5 A6 {好的那我们按照顺序了解下,连接器是啥?
    1 w/ v7 n  ]% b/ T我们要进行查询,第一步就是先去链接数据库,那这个时候就是连接器跟我们对接。: F- F% O3 x9 X, {# p1 P

    & X7 Q4 `8 h$ e- C# ]他负责跟客户端建立链接、获取权限、维持和管理连接。; ?: b* t  O% ]
    9 N# X9 {/ W1 k" d
    链接的时候会经过TCP握手,然后身份验证,然后我们输入用户名密码就好了。
    2 r2 J( t, m2 y3 M% Q  m
    0 |. i0 H6 J" k) L) l+ x验证ok后,我们就连上了这个MySQL服务了,但是这个时候我们处于空闲状态。
    & L  ~1 i2 s- u5 b" [
    $ D" L$ [1 ~' f0 a& n& Z3 X怎么查看空闲连接列表?
    0 {$ Q+ z! a0 `show processlist,下图就是我在自己的数据库表执行命令的结果,其中的Command列显示为Sleep的这一行,就表示现在系统里面有一个空闲连接。
    , D5 m+ W* X' o. U6 M( T 2.jpg 1 H* v$ [6 W: ?' C* ~( T( p9 s
    这里需要注意的是,我们数据库的客户端太久没响应,连接器就会自动断开了,这个时间参数是wait_timeout控制住的,默认时长为8小时。  ~% @& Y9 n& d. T- d7 i' W
    7 k- T% c. ?! |8 q. |
    断开后重连的时候会报错,如果你想再继续操作,你就需要重连了。% V: J* a1 m2 j5 v9 K! ]  e

    ; q  f* d  J5 ~8 L9 g/ W7 u, L这个有个我看过的书本的案例:
    % ^. ]5 Y) P/ f* R+ a8 e% o+ ?" Z) @6 V
    一个在政府里的朋友说,他们的系统很奇怪,每天早上都得重启一下应用程序,否则就提示连接数据库失败,他们都不知道该怎么办。
    5 Z" {& n* Y; _- G5 I我分析说,按照这个错误提示,应该就是连接时间过长了,断开了连接。数据库默认的超时时间是8小时,而你们平时六点下班,下班之后系统就没有人用了,等到第二天早上九点甚至十点才上班,这中间的时间已经超过10个小时了,数据库的连接肯定就会断开了。
    % V! L  a) z4 ~7 J7 S- I: u是的,就是超出了超时时间,然后写代码的人也没注意到这个细节,所以才会出现这个问题。/ [6 z+ S( v4 Q
    5 B% [' o" S+ {, t
    把超时时间改得长一点,问题就解决了。
    4 |0 H% j5 u* e. M2 L) D/ y' ], N5 X- ?
    这种参数其实我们平时不一定能接触到,但是真的遇到问题的时候,知道每个参数的大概用法,不至于让你变成无头苍蝇。
    3 N6 J# h6 O* Z7 ?" {/ v. i5 ^  C) S( `9 C" Q2 E
    那除了重新链接,还有别的方式么?因为建立链接还是比较麻烦的。9 J) g) `1 G- C( Q
    使用长连接。) ?6 Z4 V+ w) [4 d" B

    " t  @  X  M) P2 m9 U& _, d# C但是这里有个缺点,使用长连接之后,内存会飙得很快,我们知道MySQL在执行过程中临时使用的内存是管理在连接对象里面的。+ y3 R9 ~9 b: a# @/ @

    $ d0 d" Q6 Z% s& S5 ?" `  m% P只有在链接断开的时候才能得到释放,那如果一直使用长连接,那就会导致OOM(Out Of Memory),会导致MySQL重启,在JVM里面就会导致频繁的Full GC。
    . Y. A+ _* u' u' i4 K' ?+ T8 F5 A, h  g2 Z9 {5 L
    那你会怎么解决?8 Y; j, c( d  \% a" m* N
    我一般会定期断开长连接,使用一段时间后,或者程序里面判断执行过一个占用内存比较大的查询后就断开连接,需要的时候重连就好了。' x& T0 i) Q# N# ]

    0 m: v' R" W" i* j还有别的方法么?你这种感觉不优雅呀小老弟。" g# b2 p0 M( S8 `
    执行比较大的一个查询后,执行mysql_reset_connection可以重新初始化连接资源。这个过程相比上面一种会好点,不需要重连,但是会初始化连接的状态。
    + ~, u, R) j4 }! i& A0 \) e3 c
    2 C* v% D% b$ ^你了解MySQL的查询缓存么?( V- f9 T7 w- I$ O" |' D. q- m
    MySQL拿到一个查询请求后,会先到查询缓存看看,之前是不是执行过这条语句。
    ( E4 _! f/ w( S8 Y7 E, T' g4 M0 @' e" R) K! E9 k) t5 J5 J
    大家是不是好奇同一条语句在MySQL执行两次,第一次和后面的时间是不一样的,后者明显快一些,这就是因为缓存的存在。
    * f1 s& ~" j8 q6 V' a$ }
      J- H3 X" P8 g& f) ]他跟Redis一样,只要是你之前执行过的语句,都会在内存里面用key-value形式存储着。$ G2 D) U% j: J$ v6 @

    # z, w/ q5 H% g$ v查询的时候就会拿着语句先去缓存中查询,如果能够命中就返回缓存的value,如果不命中就执行后面的阶段。
    7 R0 |) c( d( h* S( O1 N8 _7 e8 p: V! j+ J& U- J
    但是我还是不喜欢用缓存,因为缓存弊大于利。/ ~' c* X$ ~- d9 D1 |
    ! i: S( f% d0 Z6 o' q
    哦?此话怎讲?& ?# A: I5 B1 Z$ u9 w
    缓存的失效很容易,只要对表有任何的更新,这个表的所有查询缓存就会全部被清空,就会出现缓存还没使用,就直接被清空了,或者积累了很多缓存准备用来着,但是一个更新打回原形。3 L# ^) V, V& H: T2 ]

    : Z, [9 f4 D. F8 C这就导致查询的命中率低的可怕,只有那种只查询不更新的表适用缓存,但是这样的表往往很少存在,一般都是什么配置表之类的。
    0 e; z* M* j: K! Z$ K& t$ F% P5 j$ A6 S
    那我们查询的时候不想用缓存一般都是怎么操作的,或者是用缓存又怎么操作?
    / G( Y* C. `: [! ~# ^) u可以显示调用,把query_cache_type设置成为DEMAND,这样SQL默认不适用缓存,想用缓存就用SQL_CACHE。, ^# S: H7 M8 k- ^& ^  b8 G& @3 n
    7 H/ d' T6 h. C# f
    有个小技巧就是,我们之前开发的时候,都会去库里看看sql执行时间,但是可能是有缓存的,一般我们就在sql前面使用SQL_NO_CACHE就可以知道真正的查询时间了。
    , O* ^- o+ a/ c, w8 k" b* B* c3 ^% a, @7 M! y
    select SQL_NO_CACHE * from B
    . u0 h% e: x2 G! v3 |1 R缓存在MySQL8.0之后就取消了,所以大家现在应该不需要太关注这个问题,主要是我之前用的版本都不高,所以缓存一直有,在《高性能MySQL》书中也看到了一些关于缓存的介绍,就想起来给大家也提一下了。
    3 b  h" a4 u- v* T
    ; l+ |6 g. \. u2 j* {9 L+ u缓存查询完了应该做啥呢?1 m* y0 a' s- @* N0 H+ ]" v
    在缓存没有命中的情况下,就开始执行语句了,你写的语句有没有语法错误,这是接下来MySQL比较关心的点。! w5 M- N5 C) G3 k. @6 n! F+ w
    ! k5 v  w" ]5 g& q% d6 r% q0 B
    那他会怎么做呢?会先做词法分析,你的语句有这么多单词、空格,MySQL就需要识别每个字符串所代表的是什么,是关键字,还是表名,还是列名等等。# Z9 ~, |& g4 i; s3 V" O2 Y$ P
    . o6 H: T& ~! H( ~3 q  L
    然后就开始语法分析,根据词法分析的结果,语法分析会判断你sql的对错,错了会提醒你的,并且会提示你哪里错了。  s' t; H$ }* k7 w
    3.jpg - I4 U  l  o5 n( z: W* A- U! C
    分析没错之后就进入下一步,优化器。
    . g/ H) A. {6 t; r. C
    ( g6 r" z+ U- B& }" }" x主要是优化什么呢?* @3 W; d/ z+ ~: s/ j' A# T
    优化就比较简单了,因为我们建立表可能会建立很多索引,优化有一步就是要确认使用哪个索引,比如使用你的主键索引,联合索引还是什么索引更好。& [, W8 d% M" i

    $ F- A" k& n$ q  q6 C还有就是对执行顺序进行优化,条件那么多,先查哪个表,还是先关联,会出现很多方案,最后由优化器决定选用哪种方案。
      a* B; \0 {5 v/ ]# Y3 c( x5 @0 z% {3 B: I: G
    最后就是执行了,执行就交给执行器去做。# d  Z- }1 k! C

    0 `: V' ]# h9 H2 ?* p第一步可能就是权限的判断,其实这里我不确定的一个点就是,我接触的公司很多都是自研的线上查询系统,我们是不能用Navicat直连线上库,只能去网页操作,那表的权限是在MySQL层做的,还是系统做的,我猜应该是系统层做的,MySQL可能默认就全开放了,只是我们 不知道ip。
    # k# s3 c% J, M. G: d& ^- U4 l6 ]3 `
      B2 O! r4 p" t9 L有知道的小伙伴也可以在公众号【三太子敖丙】去加我微信跟我说。
    0 X% l. Q& Q* x# l: U. }4 U
    % J/ F3 H  M' q" u( J1 P+ R执行的时候,就一行一行的去判断是否满足条件,有索引的执行起来可能就好点,一行行的判断就像是接口都提前在引擎定义好了,所以他比较快。- u' p5 r! h5 Q8 U
    % H" S7 j3 d' x5 E9 ~. U5 |' j2 k: a
    数据库的慢日志有个rows_examined字段,扫描多少行可以看到,还有explain也可以看到执行计划,我们扫描了多少行。' l5 k# r) A! a" `4 T* J
    . U3 j& S- L" r! w
    可以小伙子,基础大致框架还是了解得很清楚的,我们下次深入了解下,索引和部分机制。
    ( `2 k2 V" Y8 Y' d好的,我们下次见。& M0 Q. ~( \+ H

    & H3 Y' w  S) Z1 X6 E, {7 w总结
    ! y! T' H* ~7 }7 I- I+ ]0 S9 S4 k- z5 N. y- k
    基本上我把MySQL的逻辑架构的东西都简单聊了一遍,当然你去自信了解的话,你会发现其实里面还有很多细节的,我只是说了一些常见的问题,这还是阿里丁奇学长的《MySQL实战》的思路。) A. b. s9 i$ t3 D- M8 F
    + h+ T, {, @' R
    我自己在MySQL方面更多的可能就是理论知识了,还做不到深入了解的地步,大家如果有机会一定要深入的去学习一下。
    + O/ Z% c# N& G: v# U1 j6 B( c————————————————
    . C6 ?5 X# K# v: ]7 O0 V版权声明:本文为CSDN博主「敖 丙」的原创文章,遵循 CC 4.0 BY 版权协议,转载请附上原文出处链接及本声明。) S, H+ L$ N' p! {* Y
    原文链接:https://blog.csdn.net/qq_35190492/article/details/104203466
    / C3 q& `2 J: `" o8 j5 Y* B8 A0 K
    7 y" Q( o0 @& ?$ r5 D* z9 y5 k0 v, h
    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-5-26 00:41 , Processed in 0.427763 second(s), 54 queries .

    回顶部