QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2525|回复: 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
    拼多多面试问了数据库基础知识,今天分享出来
    8 @7 Y2 R! d. n3 x4 r/ M8 j, R7 F2 ?2 n1 H% v: R
    前言& K. z! P3 }1 t* A( I9 \

    ( A/ S7 W8 e2 p- Z我是个标题党,所有文章的名字只是我的噱头,我们应该有一颗谦逊的心,所以希望大家怀着空杯心态好好学,一起进步。
    ( a9 R  v1 I  A% F
    . e8 V: ~4 P6 V0 U4 }, Z数据库我想大家应该一点都不陌生吧,我想不管你写啥的,数据库就算没用过也听过了,是我们项目体系里面不可或缺的一环。5 v- K" N+ W; U; {
    3 E' q0 V4 c4 d/ `7 B
    问了一圈,身边朋友公司要么用自研,要么就清一色的MySQL,所以想看Oracle的朋友可能要失望了,但是不影响你了解数据库的通用知识。* w2 q3 j- P$ z+ F1 i
    - b4 \$ h) x& A6 D6 g
    正文
    - e+ P1 r* @3 P; M8 t
    7 @) G; P0 ^; D  O你知道MySQL的基本架构么?你能在纸上给我大致画出这个示意图么?
    # G$ A% Q! W9 A  T  f1 l$ d 1.jpg
    2 `; I" l' |1 X) D4 R好的那我们按照顺序了解下,连接器是啥?' P/ s3 t1 o' K1 ~$ M  L
    我们要进行查询,第一步就是先去链接数据库,那这个时候就是连接器跟我们对接。  z+ F( ~) S$ b  t; ?9 D
    , A- ]* |0 v2 q, b# d$ P' @% G
    他负责跟客户端建立链接、获取权限、维持和管理连接。
    " K; K* |9 R/ }4 N/ ?. {- V
    7 G  M+ v7 B3 o链接的时候会经过TCP握手,然后身份验证,然后我们输入用户名密码就好了。/ [% O, H4 a0 X; E

    7 x7 H5 ]# n8 A& G' a: `验证ok后,我们就连上了这个MySQL服务了,但是这个时候我们处于空闲状态。
    6 p/ ]9 y! B" e! F9 B  z! t
    ; ~6 ~+ d9 l; S/ @* a, x怎么查看空闲连接列表?
    8 V. |# a0 |* I2 ?show processlist,下图就是我在自己的数据库表执行命令的结果,其中的Command列显示为Sleep的这一行,就表示现在系统里面有一个空闲连接。% T  E0 O- Q% U
    2.jpg 5 d8 v) e5 l, r- S5 r2 {
    这里需要注意的是,我们数据库的客户端太久没响应,连接器就会自动断开了,这个时间参数是wait_timeout控制住的,默认时长为8小时。2 {: c* X0 b4 O* y) J: j3 U

    5 ~  z$ R2 Z- L- b" _, C# U断开后重连的时候会报错,如果你想再继续操作,你就需要重连了。
    5 {" t$ ?. G# M3 C+ i, T
    " G% S% `# f8 ]# ]这个有个我看过的书本的案例:% n/ b9 p  c4 g5 ~, x) i0 c1 H
    9 S$ d1 \+ s+ {# B! D5 o
    一个在政府里的朋友说,他们的系统很奇怪,每天早上都得重启一下应用程序,否则就提示连接数据库失败,他们都不知道该怎么办。8 B! V6 i  `( S  H' o) ^9 T- t, _
    我分析说,按照这个错误提示,应该就是连接时间过长了,断开了连接。数据库默认的超时时间是8小时,而你们平时六点下班,下班之后系统就没有人用了,等到第二天早上九点甚至十点才上班,这中间的时间已经超过10个小时了,数据库的连接肯定就会断开了。
    ( I( i4 x, c$ f% b% r' ?+ n是的,就是超出了超时时间,然后写代码的人也没注意到这个细节,所以才会出现这个问题。
    0 u% P% W% r. G9 C, R' r! Z) v: K( U3 J& s2 `
    把超时时间改得长一点,问题就解决了。0 z. w% U9 k! s, _  b0 p' }$ n

    , z6 u. X- n- s. x. I这种参数其实我们平时不一定能接触到,但是真的遇到问题的时候,知道每个参数的大概用法,不至于让你变成无头苍蝇。9 f- ^& s. {; A1 h3 Q9 i1 `
    * z1 F4 t( {% W
    那除了重新链接,还有别的方式么?因为建立链接还是比较麻烦的。
    " z0 m" c$ s4 P, b: F使用长连接。
    ; u6 ~: g' [0 O# Y5 n0 _. \0 b  i+ O" a9 D
    但是这里有个缺点,使用长连接之后,内存会飙得很快,我们知道MySQL在执行过程中临时使用的内存是管理在连接对象里面的。
    : e8 l' h/ p* f3 Q- r$ b
    4 D' {. X4 {4 w3 [只有在链接断开的时候才能得到释放,那如果一直使用长连接,那就会导致OOM(Out Of Memory),会导致MySQL重启,在JVM里面就会导致频繁的Full GC。
    1 p7 i0 T+ ~9 ~3 a
    7 M+ y2 I5 n1 X. D* l9 I  ]* z那你会怎么解决?2 X) S7 {4 B) w# @
    我一般会定期断开长连接,使用一段时间后,或者程序里面判断执行过一个占用内存比较大的查询后就断开连接,需要的时候重连就好了。
    ) o" }+ C4 _  [- m5 v5 @* U: c: B. c$ U+ o2 {2 {# T/ `3 ?
    还有别的方法么?你这种感觉不优雅呀小老弟。& G% D7 U9 f( A4 h4 T6 _# ^
    执行比较大的一个查询后,执行mysql_reset_connection可以重新初始化连接资源。这个过程相比上面一种会好点,不需要重连,但是会初始化连接的状态。
    8 D. ]1 D5 x, L  o8 ~  |7 I; ?, n) Z, d
    你了解MySQL的查询缓存么?
    - ^* ^1 {& B: `; a/ X  u4 |% l7 {, h* @MySQL拿到一个查询请求后,会先到查询缓存看看,之前是不是执行过这条语句。. V0 x& O* H$ f' R' Q; }  @

    2 f$ C. ?3 X- G+ Y% C9 N大家是不是好奇同一条语句在MySQL执行两次,第一次和后面的时间是不一样的,后者明显快一些,这就是因为缓存的存在。
    & f$ n8 Z- Z8 T4 N& ^8 D9 Y+ L; S" `+ t
    他跟Redis一样,只要是你之前执行过的语句,都会在内存里面用key-value形式存储着。
    / A' @4 u2 I' q* c4 l
    3 A4 h7 C) e* z. A查询的时候就会拿着语句先去缓存中查询,如果能够命中就返回缓存的value,如果不命中就执行后面的阶段。8 y/ _; q- y& q: @! k8 O
    . v6 ]% ~! V8 Y' `
    但是我还是不喜欢用缓存,因为缓存弊大于利。
    5 g# k$ Z7 Q. b' a1 G6 ^4 Y7 P6 h5 u1 U7 S6 f7 R2 p0 {
    哦?此话怎讲?* d9 l1 [7 z# L' c( Z+ I, T
    缓存的失效很容易,只要对表有任何的更新,这个表的所有查询缓存就会全部被清空,就会出现缓存还没使用,就直接被清空了,或者积累了很多缓存准备用来着,但是一个更新打回原形。
    % m- G5 W1 z( c# H: Z' Y! U
    / o, `& }) A- T$ @这就导致查询的命中率低的可怕,只有那种只查询不更新的表适用缓存,但是这样的表往往很少存在,一般都是什么配置表之类的。
    : x2 u# `# \4 X, q4 E% b9 J; V* J# z/ G, t  D% n! s
    那我们查询的时候不想用缓存一般都是怎么操作的,或者是用缓存又怎么操作?
    4 \+ p. \7 M6 ]1 j! ]" [/ _可以显示调用,把query_cache_type设置成为DEMAND,这样SQL默认不适用缓存,想用缓存就用SQL_CACHE。
    : K8 p: U8 i6 ?$ I/ B2 @' t8 P2 f6 k$ w2 f. j
    有个小技巧就是,我们之前开发的时候,都会去库里看看sql执行时间,但是可能是有缓存的,一般我们就在sql前面使用SQL_NO_CACHE就可以知道真正的查询时间了。. M9 I3 O& E! L& `8 G) `$ w
    # \# v( B2 b+ j
    select SQL_NO_CACHE * from B5 P$ _9 J; Z: H, T8 Q
    缓存在MySQL8.0之后就取消了,所以大家现在应该不需要太关注这个问题,主要是我之前用的版本都不高,所以缓存一直有,在《高性能MySQL》书中也看到了一些关于缓存的介绍,就想起来给大家也提一下了。1 w- ?8 X+ ]% O6 x
    ' A( j" w* C* n$ z1 X# {
    缓存查询完了应该做啥呢?
    3 G+ O" z8 U! u7 a在缓存没有命中的情况下,就开始执行语句了,你写的语句有没有语法错误,这是接下来MySQL比较关心的点。
    ; ?* Z8 f0 u7 v  o$ Q6 I) J( {4 i
    那他会怎么做呢?会先做词法分析,你的语句有这么多单词、空格,MySQL就需要识别每个字符串所代表的是什么,是关键字,还是表名,还是列名等等。# f9 H; T) g( q, e5 Z
    6 M; u- }3 {+ L0 l/ Q3 E
    然后就开始语法分析,根据词法分析的结果,语法分析会判断你sql的对错,错了会提醒你的,并且会提示你哪里错了。
      U1 `, y3 {( l8 n) E+ M 3.jpg ; J6 x2 A2 W) D& M
    分析没错之后就进入下一步,优化器。2 v6 {/ ^9 n5 i6 j' g$ q& i* ?

    * ?5 N# b. B- T5 u0 c, S$ _主要是优化什么呢?
    & r& a8 v9 s  Q; Z4 V优化就比较简单了,因为我们建立表可能会建立很多索引,优化有一步就是要确认使用哪个索引,比如使用你的主键索引,联合索引还是什么索引更好。
    " e1 y) [: C1 y, z$ ~1 j" S
    : C5 ]) {' I1 e( b8 x" s! q: m还有就是对执行顺序进行优化,条件那么多,先查哪个表,还是先关联,会出现很多方案,最后由优化器决定选用哪种方案。* u. ^$ x) ^, G  N0 y3 E
    : r. e: `+ Z* T! x7 ~
    最后就是执行了,执行就交给执行器去做。
    0 j2 m/ `' I, L, T1 U8 Q% I
    0 Y7 @  S1 f  i' S5 v/ y- ^% B) T第一步可能就是权限的判断,其实这里我不确定的一个点就是,我接触的公司很多都是自研的线上查询系统,我们是不能用Navicat直连线上库,只能去网页操作,那表的权限是在MySQL层做的,还是系统做的,我猜应该是系统层做的,MySQL可能默认就全开放了,只是我们 不知道ip。
    8 g& ^# Y/ `. X0 A& P
    1 G! G* d0 J8 n8 c; E6 {有知道的小伙伴也可以在公众号【三太子敖丙】去加我微信跟我说。
    ' X  h- v3 K# ~, [% R# b* Q+ @
    / J0 d' b0 Z4 p# L1 s# z& I+ c& ?执行的时候,就一行一行的去判断是否满足条件,有索引的执行起来可能就好点,一行行的判断就像是接口都提前在引擎定义好了,所以他比较快。2 O% B" \$ |* o

    " [; L! B1 d7 e1 g+ Z$ m, C1 m2 R8 H数据库的慢日志有个rows_examined字段,扫描多少行可以看到,还有explain也可以看到执行计划,我们扫描了多少行。" q* V- s4 L9 h9 W& q
    % x5 x- O/ L% x' R
    可以小伙子,基础大致框架还是了解得很清楚的,我们下次深入了解下,索引和部分机制。% w0 b9 j, O$ F! J1 ^; ^+ M$ }5 B
    好的,我们下次见。
    ; [0 D& r+ Y' m) o, G& z4 P# H
    5 ~. f/ H8 `  O  I, r总结
    ! Y  r: a% p( Z0 ^) h  z* d% J
    ! t/ r$ L& w' {0 H基本上我把MySQL的逻辑架构的东西都简单聊了一遍,当然你去自信了解的话,你会发现其实里面还有很多细节的,我只是说了一些常见的问题,这还是阿里丁奇学长的《MySQL实战》的思路。9 o" y1 n3 {' G. B' e2 o8 U& z

    2 \( d% W; V4 S6 u5 i+ |我自己在MySQL方面更多的可能就是理论知识了,还做不到深入了解的地步,大家如果有机会一定要深入的去学习一下。! j3 n8 t1 ?2 [( s6 f
    ————————————————1 h7 F6 g, q9 G% o' w; L
    版权声明:本文为CSDN博主「敖 丙」的原创文章,遵循 CC 4.0 BY 版权协议,转载请附上原文出处链接及本声明。& _; h+ W6 [1 J5 A: b
    原文链接:https://blog.csdn.net/qq_35190492/article/details/104203466
    4 u! L" f3 w/ I1 G$ V9 [3 x6 d. F6 |' r# N6 I

    ' b; J2 Y! Z. {1 Y3 ~# F* 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 10:12 , Processed in 0.449986 second(s), 58 queries .

    回顶部