博客
关于我
蚂蚁金服内部的这份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 创建函数 Error Code : 1418
    查看>>
    MySQL 创建新用户及授予权限的完整流程
    查看>>
    mysql 创建表,不能包含关键字values 以及 表id自增问题
    查看>>
    mysql 删除日志文件详解
    查看>>
    mysql 判断表字段是否存在,然后修改
    查看>>
    MySQL 到底能不能放到 Docker 里跑?
    查看>>
    mysql 前缀索引 命令_11 | Mysql怎么给字符串字段加索引?
    查看>>
    MySQL 加锁处理分析
    查看>>
    mysql 协议的退出命令包及解析
    查看>>
    mysql 参数 innodb_flush_log_at_trx_commit
    查看>>
    mysql 取表中分组之后最新一条数据 分组最新数据 分组取最新数据 分组数据 获取每个分类的最新数据
    查看>>
    MySQL 命令和内置函数
    查看>>
    mysql 四种存储引擎
    查看>>
    MySQL 在并发场景下的问题及解决思路
    查看>>
    MySQL 基础架构
    查看>>
    MySQL 基础模块的面试题总结
    查看>>
    MySQL 备份 Xtrabackup
    查看>>
    mYSQL 外键约束
    查看>>
    mysql 多个表关联查询查询时间长的问题
    查看>>
    mySQL 多个表求多个count
    查看>>