QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2141|回复: 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
    拼多多面试问了数据库基础知识,今天分享出来$ o6 Q, U& N- l! T$ x  j
    ) Z7 X2 |1 E; ~8 u
    前言
    & F7 Z4 {" x- u/ f) w: M! V; p# x9 K
    我是个标题党,所有文章的名字只是我的噱头,我们应该有一颗谦逊的心,所以希望大家怀着空杯心态好好学,一起进步。
    . [5 c/ ^1 X9 ]
    # @6 |( J/ p$ E1 _数据库我想大家应该一点都不陌生吧,我想不管你写啥的,数据库就算没用过也听过了,是我们项目体系里面不可或缺的一环。+ Z0 c, Y; l* p
    & [$ k) ?. U3 r% ]3 }
    问了一圈,身边朋友公司要么用自研,要么就清一色的MySQL,所以想看Oracle的朋友可能要失望了,但是不影响你了解数据库的通用知识。
    + p: V, \# r3 d
    ( O# l  i7 I7 s$ E  G正文
    * ]  J3 _4 D, ~: h$ Z$ Y0 G$ n  {0 I) q! t* V/ {' H2 ^
    你知道MySQL的基本架构么?你能在纸上给我大致画出这个示意图么?  s5 B$ \1 W0 u9 U! l
    1.jpg
    ) e5 Z- T  d4 K' P* m. s) i好的那我们按照顺序了解下,连接器是啥?( Y, N7 \( W: }! b3 _/ C( _6 T
    我们要进行查询,第一步就是先去链接数据库,那这个时候就是连接器跟我们对接。4 b' O! B, G# n' S- S

    5 J9 s' G% `$ s7 @. S9 X5 y他负责跟客户端建立链接、获取权限、维持和管理连接。3 ]# [( T2 S! F$ X3 [
    5 w0 S, B8 I( U( ]- s: ~3 c9 i: y
    链接的时候会经过TCP握手,然后身份验证,然后我们输入用户名密码就好了。; M7 k# W2 k1 u
    0 e" a( u9 a# p+ ^
    验证ok后,我们就连上了这个MySQL服务了,但是这个时候我们处于空闲状态。4 k0 f: ^5 [: m4 H8 H

    ) R7 m0 L( t( W6 |) p5 r0 @怎么查看空闲连接列表?4 `! p& ]5 {7 X+ c* E) R
    show processlist,下图就是我在自己的数据库表执行命令的结果,其中的Command列显示为Sleep的这一行,就表示现在系统里面有一个空闲连接。$ M  C* ]( }6 ?7 c1 S0 j) h
    2.jpg
    ! ]8 P! K4 v( G! j( I, ]' j4 L这里需要注意的是,我们数据库的客户端太久没响应,连接器就会自动断开了,这个时间参数是wait_timeout控制住的,默认时长为8小时。
    : Q- w; o' ?$ a9 {1 p; L
    $ b7 {2 S2 u3 P* _. k" O5 `断开后重连的时候会报错,如果你想再继续操作,你就需要重连了。
    4 d) {# b" I, c" e; @% u3 D) ~. b
    6 }0 ^2 g5 ~( v* G6 x这个有个我看过的书本的案例:
    9 ?0 V7 `! U+ y3 H# J. o6 x( i/ i. l
    , w+ j* G- W& O5 d& z: ?一个在政府里的朋友说,他们的系统很奇怪,每天早上都得重启一下应用程序,否则就提示连接数据库失败,他们都不知道该怎么办。
    # L# X/ [( n# _: l4 W8 a, ]. T我分析说,按照这个错误提示,应该就是连接时间过长了,断开了连接。数据库默认的超时时间是8小时,而你们平时六点下班,下班之后系统就没有人用了,等到第二天早上九点甚至十点才上班,这中间的时间已经超过10个小时了,数据库的连接肯定就会断开了。
    ; k- J* L# m5 Y: R是的,就是超出了超时时间,然后写代码的人也没注意到这个细节,所以才会出现这个问题。
    - u0 I6 ?2 s5 F" l4 D: q& E3 O; M6 l/ Q; J8 C
    把超时时间改得长一点,问题就解决了。
    4 D4 p+ L! I/ F& o' `
    ' T3 D9 Q+ t  J6 L这种参数其实我们平时不一定能接触到,但是真的遇到问题的时候,知道每个参数的大概用法,不至于让你变成无头苍蝇。5 O6 ~% ^! m0 {8 `
    $ I* ~9 s" Y6 k4 {! X  _8 W* @
    那除了重新链接,还有别的方式么?因为建立链接还是比较麻烦的。
    + |+ p0 ~  f, n3 T使用长连接。
    6 L. I/ H% y% W
    $ L. {0 Z$ f8 d但是这里有个缺点,使用长连接之后,内存会飙得很快,我们知道MySQL在执行过程中临时使用的内存是管理在连接对象里面的。; k: l  k* d; }' y3 X' B

    ; w6 L) b: D9 c4 N只有在链接断开的时候才能得到释放,那如果一直使用长连接,那就会导致OOM(Out Of Memory),会导致MySQL重启,在JVM里面就会导致频繁的Full GC。! g8 A& L+ h* p' N/ o
    , `: k* T2 v2 O! v1 l. o
    那你会怎么解决?
    " V% m  g: S: u4 x我一般会定期断开长连接,使用一段时间后,或者程序里面判断执行过一个占用内存比较大的查询后就断开连接,需要的时候重连就好了。3 \& g: o# q9 S0 B) t. l; P

    ( S" E( z. r5 b3 Z% E- m还有别的方法么?你这种感觉不优雅呀小老弟。; J$ j5 N. D' I8 f
    执行比较大的一个查询后,执行mysql_reset_connection可以重新初始化连接资源。这个过程相比上面一种会好点,不需要重连,但是会初始化连接的状态。; i1 Z) o; h! p6 D2 o) j5 _  A
    * ^7 h' u/ v  _" M6 F& T- @* H4 R' W
    你了解MySQL的查询缓存么?
    ! H* V! ^6 a0 o- |MySQL拿到一个查询请求后,会先到查询缓存看看,之前是不是执行过这条语句。6 h0 ]: F& w4 `1 ]5 U: E$ c  G5 u
    ; n7 f- Y, U1 f
    大家是不是好奇同一条语句在MySQL执行两次,第一次和后面的时间是不一样的,后者明显快一些,这就是因为缓存的存在。0 K% Y# s0 A2 N

    : {; A" h4 y; I# E: i+ s4 y他跟Redis一样,只要是你之前执行过的语句,都会在内存里面用key-value形式存储着。
    % k! k" b& a8 w6 w
    4 g, Q! E  a/ B查询的时候就会拿着语句先去缓存中查询,如果能够命中就返回缓存的value,如果不命中就执行后面的阶段。
    3 G( n3 ?) K2 ~2 p" ~4 ^( C4 h  U* h/ d& {: z0 L; S8 O; J9 `. K
    但是我还是不喜欢用缓存,因为缓存弊大于利。. Y& W9 Y' ~" ^, m8 e& |2 S
    * {7 J/ g8 }) K
    哦?此话怎讲?/ _1 N* o: z6 Y3 O
    缓存的失效很容易,只要对表有任何的更新,这个表的所有查询缓存就会全部被清空,就会出现缓存还没使用,就直接被清空了,或者积累了很多缓存准备用来着,但是一个更新打回原形。( L! Q" ?2 W3 u' e0 O
    8 e; W& v9 H5 N
    这就导致查询的命中率低的可怕,只有那种只查询不更新的表适用缓存,但是这样的表往往很少存在,一般都是什么配置表之类的。6 L1 C3 x9 G- q5 E" i

    0 ?; _" v/ n3 \7 ^那我们查询的时候不想用缓存一般都是怎么操作的,或者是用缓存又怎么操作?# e3 S4 A4 k5 e
    可以显示调用,把query_cache_type设置成为DEMAND,这样SQL默认不适用缓存,想用缓存就用SQL_CACHE。
    9 f: I7 h2 q2 o: w6 w
    & k# r) T/ S6 A" J. a0 C& k& _有个小技巧就是,我们之前开发的时候,都会去库里看看sql执行时间,但是可能是有缓存的,一般我们就在sql前面使用SQL_NO_CACHE就可以知道真正的查询时间了。
    / v4 C1 r; n  F. X9 i- A6 v' _+ H/ o8 x
    select SQL_NO_CACHE * from B
    # [! y" L1 p3 G  H3 t% X4 p! v- g# I/ w5 d缓存在MySQL8.0之后就取消了,所以大家现在应该不需要太关注这个问题,主要是我之前用的版本都不高,所以缓存一直有,在《高性能MySQL》书中也看到了一些关于缓存的介绍,就想起来给大家也提一下了。3 e; J1 |: R2 W6 N0 e$ [& g% K# Q

      b: n! k  D1 o* Y& ]6 C: H缓存查询完了应该做啥呢?
    , a, I5 \8 B6 u0 R在缓存没有命中的情况下,就开始执行语句了,你写的语句有没有语法错误,这是接下来MySQL比较关心的点。
    : T7 z% A" J0 P2 m9 |) |
    ; o+ u$ C/ v# H1 y% V0 T那他会怎么做呢?会先做词法分析,你的语句有这么多单词、空格,MySQL就需要识别每个字符串所代表的是什么,是关键字,还是表名,还是列名等等。) F; @- `1 i' [9 [2 s4 d* E' |- {
    1 v' ^! z4 |: p( C) `
    然后就开始语法分析,根据词法分析的结果,语法分析会判断你sql的对错,错了会提醒你的,并且会提示你哪里错了。: c  w/ E6 t& ~4 O% y! D8 x
    3.jpg $ j: U  ~) _4 q3 O% k# Y
    分析没错之后就进入下一步,优化器。
    1 u9 |! z6 }  a" r( ?  s1 |1 u' C& y( l0 X4 ?" T$ m! a
    主要是优化什么呢?
    # o% v* k8 }4 X: H优化就比较简单了,因为我们建立表可能会建立很多索引,优化有一步就是要确认使用哪个索引,比如使用你的主键索引,联合索引还是什么索引更好。
    % S6 R% r9 o5 ?6 L- N9 A8 D! j( c# @/ h
    还有就是对执行顺序进行优化,条件那么多,先查哪个表,还是先关联,会出现很多方案,最后由优化器决定选用哪种方案。" \  [" T/ O4 z, ?6 Q2 B! s& z

    4 b, s% G; a+ C1 {. V: ^  I最后就是执行了,执行就交给执行器去做。$ s; L9 x* ~7 q& L3 n* Z

    # V& d; I, c( B第一步可能就是权限的判断,其实这里我不确定的一个点就是,我接触的公司很多都是自研的线上查询系统,我们是不能用Navicat直连线上库,只能去网页操作,那表的权限是在MySQL层做的,还是系统做的,我猜应该是系统层做的,MySQL可能默认就全开放了,只是我们 不知道ip。
    8 c( W( m8 N: b& c
    - y& H; r: F& w/ f% Q有知道的小伙伴也可以在公众号【三太子敖丙】去加我微信跟我说。2 P# e  j1 ~3 c

    $ g6 u8 `) Z% F( J1 `& b执行的时候,就一行一行的去判断是否满足条件,有索引的执行起来可能就好点,一行行的判断就像是接口都提前在引擎定义好了,所以他比较快。
    6 i, Z! S9 N5 r8 c5 C
    4 ]- p9 i/ i7 h. X8 ~8 a8 T0 ?数据库的慢日志有个rows_examined字段,扫描多少行可以看到,还有explain也可以看到执行计划,我们扫描了多少行。9 G; E% P6 c5 T
    ) _% \+ V7 x$ i* S
    可以小伙子,基础大致框架还是了解得很清楚的,我们下次深入了解下,索引和部分机制。
    / X$ J! x: x' r9 f  }- t' a好的,我们下次见。+ Z0 l0 |5 M+ y- n* q

    / j/ p4 v4 j; l" E5 I0 k总结
    : W. V( v5 t$ Q; u* c% j' @3 C9 F  x3 J8 e; P3 |
    基本上我把MySQL的逻辑架构的东西都简单聊了一遍,当然你去自信了解的话,你会发现其实里面还有很多细节的,我只是说了一些常见的问题,这还是阿里丁奇学长的《MySQL实战》的思路。
    7 x( U$ D/ o5 i* P' _1 u/ P8 p, b4 z+ P0 Z8 _
    我自己在MySQL方面更多的可能就是理论知识了,还做不到深入了解的地步,大家如果有机会一定要深入的去学习一下。
    # q. W$ x8 v& k————————————————
    $ S9 G; O3 a: q% o版权声明:本文为CSDN博主「敖 丙」的原创文章,遵循 CC 4.0 BY 版权协议,转载请附上原文出处链接及本声明。4 F# l1 p' V' A/ c
    原文链接:https://blog.csdn.net/qq_35190492/article/details/1042034660 y/ o7 G: j6 q: N7 Q  o0 y
    + ^4 X& _$ k7 k' S
    : v! S# A' U& y% f
    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-8-22 07:30 , Processed in 0.607641 second(s), 54 queries .

    回顶部