博客
关于我
蚂蚁金服内部的这份MySQL学习笔记火了,完整版首次公开!
阅读量:369 次
发布时间:2019-03-05

本文共 1274 字,大约阅读时间需要 4 分钟。

MySQL学习笔记

前言

每天我们都会访问各类网站和应用程序,如微信、QQ、抖音、今日头条等。这些网站上面总会有大量的信息数据,这些数据需要有地理存储。而这些数据通常存储在数据库中。常用的数据库有MySQL、Oracle、SQLServer、DB2等。其中,Oracle在性能和服务上排名居首,但收费较高。金融公司对数据库的稳定性要求较高,通常会选择Oracle。MySQL是免费的,其他数据库暂时收费较高,MySQL在互联网公司的使用率也排名居首。资料也比较完善,社区活跃,因此我们主要学习MySQL。


数据库常见概念

  • DB:数据库,是存储数据的容器。
  • DBMS:数据库管理系统,用于创建或管理数据库。
  • SQL:结构化查询语言,用于与数据库通信。SQL不是某个数据库软件特有的,而是多数主流数据库通用。

数据库存储数据的特点

  • 数据存放在表中,表存放在数据库中。
  • 每个库可以有多张表,每张表有唯一的名称。
  • 表中可以有多个列(字段,类似Java的属性)。
  • 表中的每一行数据类似于Java中的对象。

数据类型选择建议

  • 选小不选大:选择可以正确存储数据的最小数据类型。小的数据类型通常更快,占用磁盘、内存和CPU缓存更少。
  • 简单就好:简单的数据类型操作代价较低。例如,整型比字符操作代价更低,因为字符集和校对规则会增加复杂性。
  • 尽量避免NULL:尽量将列设置为NOT NULL,除非真的需要NULL类型的值。NULL会使索引、统计和值比较更加复杂。
  • 浮点类型建议统一使用decimal
  • 记录时间建议使用int或bigint,将时间转换为时间戳格式(如秒、毫秒),便于索引

  • MySQL权限管理原理

    MySQL通过主机名+用户名来识别用户权限。在互联网络中,很难通过用户名判断用户身份,但可以通过IP或主机名判断某台机器上的用户权限。因此,MySQL采用的用户认证方式是基于用户名+来源(IP或主机名)。

    权限验证分为两个阶段:

  • 阶段1:连接数据库时,MySQL根据用户名和来源(IP或主机名)判断是否有权限连接。
  • 阶段2:对MySQL服务器发起操作请求(如Create Table、Select、Delete、Update、Create Index等),MySQL会判断是否有权限执行这些操作。

  • 如何正确使用索引

    索引的学习和使用需要了解其原理和应用,以写出更快的SQL。理解为什么某些SQL会使用索引,为什么有些不会,以及索引在数据库中的具体作用。

    索引类型

  • 聚集索引(主键索引)

    每个表都有一个聚集索引,数据以B+树结构存储。叶子节点存储主键值和完整记录,非叶子节点存储主键值。

  • 非聚集索引

    每个表可以有多个非聚集索引,B+树结构,叶子节点存储索引字段值和主键值,非叶子节点存储索引字段值。

    使用非聚集索引时,需要两次查找:第一次在非聚集索引中找到主键,第二次在聚集索引中找到对应记录。相比聚集索引,非聚集索引会增加两次查找操作。


  • 总结

    学习是一辈子的事情。通过自己做笔记并总结,可以检查学习效果,并为后续复习提供方便。自己的笔记更容易理解和记忆。

    转载地址:http://gevg.baihongyu.com/

    你可能感兴趣的文章
    MS UC 2013-0-Prepare Tool
    查看>>
    msbuild发布web应用程序
    查看>>
    MSB与LSB
    查看>>
    MSCRM调用外部JS文件
    查看>>
    MSCRM调用外部JS文件
    查看>>
    MSEdgeDriver (Chromium) 不适用于版本 >= 79.0.313 (Canary)
    查看>>
    MsEdgeTTS开源项目使用教程
    查看>>
    msf
    查看>>
    MSSQL数据库查询优化(一)
    查看>>
    MSSQL日期格式转换函数(使用CONVERT)
    查看>>
    MSTP多生成树协议(第二课)
    查看>>
    MSTP是什么?有哪些专有名词?
    查看>>
    Mstsc 远程桌面链接 And 网络映射
    查看>>
    Myeclipse常用快捷键
    查看>>
    MyEclipse用(JDBC)连接SQL出现的问题~
    查看>>
    myeclipse的新建severlet不见解决方法
    查看>>
    MyEclipse设置当前行背景颜色、选中单词前景色、背景色
    查看>>
    myeclipse配置springmvc教程
    查看>>
    MyEclipse配置SVN
    查看>>
    MTCNN 人脸检测
    查看>>