QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2278|回复: 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
    拼多多面试问了数据库基础知识,今天分享出来5 m  X$ ^- |/ P! ?
    # }0 n$ K' i; t# b" ^5 W9 j
    前言7 E; E* ~" k# H
    9 [' [, D! x6 o! C, h
    我是个标题党,所有文章的名字只是我的噱头,我们应该有一颗谦逊的心,所以希望大家怀着空杯心态好好学,一起进步。1 T0 l4 r' H+ I5 J  w+ ~/ `3 R

    1 ^% U& A1 q: B+ |' ~数据库我想大家应该一点都不陌生吧,我想不管你写啥的,数据库就算没用过也听过了,是我们项目体系里面不可或缺的一环。
    , B+ S- {( ~% s8 `' |- R) R
    - x: M9 t% P! N) O0 T问了一圈,身边朋友公司要么用自研,要么就清一色的MySQL,所以想看Oracle的朋友可能要失望了,但是不影响你了解数据库的通用知识。
    8 _4 p! {$ h/ r/ o- k3 @; i) r) f% B/ s
    正文6 w& c1 k8 M4 E  Y4 v0 _+ Y
    7 O7 P( |$ b& y1 d/ C; o
    你知道MySQL的基本架构么?你能在纸上给我大致画出这个示意图么?
    8 {: E+ u) B5 ]0 q 1.jpg % r6 j' _' ~2 J* k2 L  B% J
    好的那我们按照顺序了解下,连接器是啥?
    ) e* \# m0 f- I: G8 k我们要进行查询,第一步就是先去链接数据库,那这个时候就是连接器跟我们对接。
    & W: l0 N$ p7 t& C' D4 w1 m4 m1 j0 f, C2 y" B% C
    他负责跟客户端建立链接、获取权限、维持和管理连接。
    : `3 w: T  M* i) F4 V
    ( [$ @. I2 \3 f4 \链接的时候会经过TCP握手,然后身份验证,然后我们输入用户名密码就好了。
    7 Z/ b+ c& k: u/ z2 y/ S; X% H8 P: w! g$ ?- r# h2 L
    验证ok后,我们就连上了这个MySQL服务了,但是这个时候我们处于空闲状态。
    . t+ P: G# v+ G4 H  |$ x8 |* `$ R, i& q- \
    怎么查看空闲连接列表?
    / C3 J; n! C. Vshow processlist,下图就是我在自己的数据库表执行命令的结果,其中的Command列显示为Sleep的这一行,就表示现在系统里面有一个空闲连接。
    ( _  u& R2 r3 N+ D1 z7 \ 2.jpg 8 Q2 O6 u5 x) P) w
    这里需要注意的是,我们数据库的客户端太久没响应,连接器就会自动断开了,这个时间参数是wait_timeout控制住的,默认时长为8小时。
    ( M$ }2 T; H1 _6 A8 Z/ J" N/ b: c4 ?5 {0 c
    断开后重连的时候会报错,如果你想再继续操作,你就需要重连了。
    " B- ~2 w% c9 Y% T$ s; A( r8 y4 _1 [1 s1 W
    这个有个我看过的书本的案例:
    & ?/ X: K4 C, h/ {. r& y
    7 F( ], K2 I0 T  i  s) ]9 f- h一个在政府里的朋友说,他们的系统很奇怪,每天早上都得重启一下应用程序,否则就提示连接数据库失败,他们都不知道该怎么办。
    5 _5 H4 P( A+ S* j我分析说,按照这个错误提示,应该就是连接时间过长了,断开了连接。数据库默认的超时时间是8小时,而你们平时六点下班,下班之后系统就没有人用了,等到第二天早上九点甚至十点才上班,这中间的时间已经超过10个小时了,数据库的连接肯定就会断开了。
    , H2 b  i/ i9 K7 G3 K2 a' Z是的,就是超出了超时时间,然后写代码的人也没注意到这个细节,所以才会出现这个问题。# m2 _" m. J* H

    9 z, s; _" ?5 n/ l# y4 |& i$ F把超时时间改得长一点,问题就解决了。; ]/ X1 Q3 G5 d* @2 K
    * ~& f2 [+ N' ~+ ~
    这种参数其实我们平时不一定能接触到,但是真的遇到问题的时候,知道每个参数的大概用法,不至于让你变成无头苍蝇。
    + H! L8 Z- |: y
    8 d% l$ e1 D/ W, E' R那除了重新链接,还有别的方式么?因为建立链接还是比较麻烦的。
    + q7 n1 F! H% R# |1 r4 i3 B使用长连接。+ o, J! Q1 F" [  E

    & }. V2 Z9 r3 [/ |- T' |但是这里有个缺点,使用长连接之后,内存会飙得很快,我们知道MySQL在执行过程中临时使用的内存是管理在连接对象里面的。5 f) N! U9 \7 }- x# L
    4 S" j/ n: s2 X* b8 o
    只有在链接断开的时候才能得到释放,那如果一直使用长连接,那就会导致OOM(Out Of Memory),会导致MySQL重启,在JVM里面就会导致频繁的Full GC。
    , ?  \$ A0 u% w9 y9 X6 ^2 x2 x1 R9 s& d$ J& d
    那你会怎么解决?
    7 z! {0 W$ W: F我一般会定期断开长连接,使用一段时间后,或者程序里面判断执行过一个占用内存比较大的查询后就断开连接,需要的时候重连就好了。
    $ e( D+ {6 y! m! i5 l+ q* B; W6 \- Z# P# f* \
    还有别的方法么?你这种感觉不优雅呀小老弟。+ M/ H! n8 O6 Y( q9 w# S
    执行比较大的一个查询后,执行mysql_reset_connection可以重新初始化连接资源。这个过程相比上面一种会好点,不需要重连,但是会初始化连接的状态。
    + E4 c1 }# L6 F; z6 N
    # H0 q. y( R: s' [你了解MySQL的查询缓存么?
    * ~* W! u% @- D% i2 e' }) ?MySQL拿到一个查询请求后,会先到查询缓存看看,之前是不是执行过这条语句。, Q- q, H9 [' k+ I4 a
    * q# ~' r( B# `; R
    大家是不是好奇同一条语句在MySQL执行两次,第一次和后面的时间是不一样的,后者明显快一些,这就是因为缓存的存在。2 m+ l, m' ]  X* W( O' B- L

    3 M! i& ?6 C, ~6 V他跟Redis一样,只要是你之前执行过的语句,都会在内存里面用key-value形式存储着。
    . N+ V3 E6 f$ m# v+ W4 s3 d3 z5 i3 [. n
    查询的时候就会拿着语句先去缓存中查询,如果能够命中就返回缓存的value,如果不命中就执行后面的阶段。+ l0 n4 y2 ?- u' D, S
    3 X! x  P" o. t+ A6 ^
    但是我还是不喜欢用缓存,因为缓存弊大于利。( t; x+ h0 Q$ F' ?

    5 _  A- o" P8 z" l6 i哦?此话怎讲?% l' l1 }% i5 Z- ^3 C# @  K2 q
    缓存的失效很容易,只要对表有任何的更新,这个表的所有查询缓存就会全部被清空,就会出现缓存还没使用,就直接被清空了,或者积累了很多缓存准备用来着,但是一个更新打回原形。: u+ |- V  Q# r( M: N; ?5 V
    ! o) Y7 }, p8 k6 d. I
    这就导致查询的命中率低的可怕,只有那种只查询不更新的表适用缓存,但是这样的表往往很少存在,一般都是什么配置表之类的。2 o+ Y! a6 O* d9 K* W
    + D, \) F$ z+ `2 `) H
    那我们查询的时候不想用缓存一般都是怎么操作的,或者是用缓存又怎么操作?
    + ?9 m2 z5 Z3 _/ A+ F& m0 ~2 f可以显示调用,把query_cache_type设置成为DEMAND,这样SQL默认不适用缓存,想用缓存就用SQL_CACHE。5 d! {) `% a0 O5 J) @- u. E
    # Q" C1 a; X* D+ `6 S3 L' K
    有个小技巧就是,我们之前开发的时候,都会去库里看看sql执行时间,但是可能是有缓存的,一般我们就在sql前面使用SQL_NO_CACHE就可以知道真正的查询时间了。! C7 \# C& E6 y: P1 _9 Y5 }# f# t
    " p$ w# Z$ ~% {6 o! `/ T0 Y" r
    select SQL_NO_CACHE * from B& u; J' n1 Y, D( X9 e' z" N
    缓存在MySQL8.0之后就取消了,所以大家现在应该不需要太关注这个问题,主要是我之前用的版本都不高,所以缓存一直有,在《高性能MySQL》书中也看到了一些关于缓存的介绍,就想起来给大家也提一下了。- ?0 Y' s8 f/ u9 ~
    ) C: i; P# X' T8 U' f
    缓存查询完了应该做啥呢?
    7 @3 Z' @/ N7 ~/ }在缓存没有命中的情况下,就开始执行语句了,你写的语句有没有语法错误,这是接下来MySQL比较关心的点。
    7 C6 m( f/ k9 Q, [, U( Y; g" w* A
    3 t- k: Y. j7 k& ^$ e; ]/ m) e8 Q那他会怎么做呢?会先做词法分析,你的语句有这么多单词、空格,MySQL就需要识别每个字符串所代表的是什么,是关键字,还是表名,还是列名等等。$ d, {  a( r. k2 K: S6 G

    1 \: @" i/ O' a+ c' z然后就开始语法分析,根据词法分析的结果,语法分析会判断你sql的对错,错了会提醒你的,并且会提示你哪里错了。
      b/ V- K3 @4 D/ I4 |  ? 3.jpg 6 Z* X& v3 e- N1 h4 X
    分析没错之后就进入下一步,优化器。* P, w- J, m, P' d" m. w
    ! ^( t$ z' l  L3 F2 z5 V" D/ P! Y  P# Z
    主要是优化什么呢?
    1 e& W- u. }7 f优化就比较简单了,因为我们建立表可能会建立很多索引,优化有一步就是要确认使用哪个索引,比如使用你的主键索引,联合索引还是什么索引更好。
    3 I/ l3 d* ~: l' W2 ~$ R* n$ ~4 D  q/ Z' B8 V, a- ^
    还有就是对执行顺序进行优化,条件那么多,先查哪个表,还是先关联,会出现很多方案,最后由优化器决定选用哪种方案。
    " G) ]( h; l1 m0 n; z
    $ \& d3 r. n* A9 O最后就是执行了,执行就交给执行器去做。
    2 F& n+ w9 w  k# h5 j: T& X/ q' H/ a! C) N! k/ N
    第一步可能就是权限的判断,其实这里我不确定的一个点就是,我接触的公司很多都是自研的线上查询系统,我们是不能用Navicat直连线上库,只能去网页操作,那表的权限是在MySQL层做的,还是系统做的,我猜应该是系统层做的,MySQL可能默认就全开放了,只是我们 不知道ip。
    0 A0 p- N, s% ], i7 n: o0 a0 |" w8 k  e( ?8 ?
    有知道的小伙伴也可以在公众号【三太子敖丙】去加我微信跟我说。# l% B9 }( [3 {$ W5 {: a* N, m' Q
    0 w& \9 j; `4 K. @( f
    执行的时候,就一行一行的去判断是否满足条件,有索引的执行起来可能就好点,一行行的判断就像是接口都提前在引擎定义好了,所以他比较快。' v9 v+ J1 O% r6 y/ c

    1 K0 q5 f/ d+ D' i9 Z  h5 x数据库的慢日志有个rows_examined字段,扫描多少行可以看到,还有explain也可以看到执行计划,我们扫描了多少行。) S% l0 }! b5 L& S! q. l

    ! M7 A* i+ G, c% ~  q可以小伙子,基础大致框架还是了解得很清楚的,我们下次深入了解下,索引和部分机制。( h8 x' U/ i0 p
    好的,我们下次见。0 A. Y# @& h7 e4 m) y* w- b4 y% o

    % c# l; i7 }1 ~总结4 H0 S) K/ H6 K$ ^9 ^. x

    % _7 z1 P7 j; Y: t4 h2 Y基本上我把MySQL的逻辑架构的东西都简单聊了一遍,当然你去自信了解的话,你会发现其实里面还有很多细节的,我只是说了一些常见的问题,这还是阿里丁奇学长的《MySQL实战》的思路。4 L/ z1 C. e8 U

    + K- t& B% E8 D; w, T* I" Y$ ]# p我自己在MySQL方面更多的可能就是理论知识了,还做不到深入了解的地步,大家如果有机会一定要深入的去学习一下。
    % m! ~, s! t4 n" F————————————————3 S8 \: W7 I5 _* C
    版权声明:本文为CSDN博主「敖 丙」的原创文章,遵循 CC 4.0 BY 版权协议,转载请附上原文出处链接及本声明。9 x7 o: @: Q/ E: U
    原文链接:https://blog.csdn.net/qq_35190492/article/details/104203466
    , J% }  p/ o2 S0 y) ?  i
    % D8 f; R. _; l- P( s. X' e0 x6 [% l1 B5 S+ w; x/ @
    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-17 00:09 , Processed in 1.469633 second(s), 53 queries .

    回顶部