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

    你可能感兴趣的文章
    Mysql中索引的分类、增删改查与存储引擎对应关系
    查看>>
    Mysql中索引的最左前缀原则图文剖析(全)
    查看>>
    MySql中给视图添加注释怎么添加_默认不支持_可以这样取巧---MySql工作笔记002
    查看>>
    Mysql中获取所有表名以及表名带时间字符串使用BetweenAnd筛选区间范围
    查看>>
    Mysql中视图的使用以及常见运算符的使用示例和优先级
    查看>>
    Mysql中触发器的使用示例
    查看>>
    Mysql中设置只允许指定ip能连接访问(可视化工具的方式)
    查看>>
    mysql中还有窗口函数?这是什么东西?
    查看>>
    mysql中间件
    查看>>
    MYSQL中频繁的乱码问题终极解决
    查看>>
    MySQL为Null会导致5个问题,个个致命!
    查看>>
    MySQL为什么不建议使用delete删除数据?
    查看>>
    MySQL主从、环境搭建、主从配制
    查看>>
    Mysql主从不同步
    查看>>
    mysql主从同步及清除信息
    查看>>
    MySQL主从同步相关-主从多久的延迟?
    查看>>
    mysql主从同步配置方法和原理
    查看>>
    mysql主从复制 master和slave配置的参数大全
    查看>>
    MySQL主从复制几个重要的启动选项
    查看>>
    MySQL主从复制及排错
    查看>>