博客
关于我
蚂蚁金服内部的这份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/

    你可能感兴趣的文章
    none 和 host 网络的适用场景 - 每天5分钟玩转 Docker 容器技术(31)
    查看>>
    None还可以是函数定义可选参数的一个默认值,设置成默认值时实参在调用该函数时可以不输入与None绑定的元素...
    查看>>
    Vue.js 学习总结(16)—— 为什么 :deep、/deep/、>>> 样式能穿透到子组件
    查看>>
    NOPI读取Excel
    查看>>
    NoSQL&MongoDB
    查看>>
    NoSQL介绍
    查看>>
    Notadd —— 基于 nest.js 的微服务开发框架
    查看>>
    Notepad ++ 安装与配置教程(非常详细)从零基础入门到精通,看完这一篇就够了
    查看>>
    Notepad++在线和离线安装JSON格式化插件
    查看>>
    notepad++最详情汇总
    查看>>
    notepad如何自动对齐_notepad++怎么自动排版
    查看>>
    Notification 使用详解(很全
    查看>>
    NotImplementedError: Cannot copy out of meta tensor; no data! Please use torch.nn.Module.to_empty()
    查看>>
    Now trying to drop the old temporary tablespace, the session hangs.
    查看>>
    nowcoder—Beauty of Trees
    查看>>
    np.arange()和np.linspace()绘制logistic回归图像时得到不同的结果?
    查看>>
    np.power的使用
    查看>>
    NPM 2FA双重认证的设置方法
    查看>>
    npm build报错Cannot find module ‘webpack/lib/rules/BasicEffectRulePlugin‘解决方法
    查看>>
    npm build报错Cannot find module ‘webpack‘解决方法
    查看>>