博客
关于我
蚂蚁金服内部的这份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 CRUD 数据表基础操作实战
    查看>>
    multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
    查看>>
    mysql csv import meets charset
    查看>>
    multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
    查看>>
    MySQL DBA 数据库优化策略
    查看>>
    multi_index_container
    查看>>
    MySQL DBA 进阶知识详解
    查看>>
    Mura CMS processAsyncObject SQL注入漏洞复现(CVE-2024-32640)
    查看>>
    Mysql DBA 高级运维学习之路-DQL语句之select知识讲解
    查看>>
    mysql deadlock found when trying to get lock暴力解决
    查看>>
    MuseTalk如何生成高质量视频(使用技巧)
    查看>>
    mutiplemap 总结
    查看>>
    MySQL DELETE 表别名问题
    查看>>
    MySQL Error Handling in Stored Procedures---转载
    查看>>
    MVC 区域功能
    查看>>
    MySQL FEDERATED 提示
    查看>>
    mysql generic安装_MySQL 5.6 Generic Binary安装与配置_MySQL
    查看>>
    Mysql group by
    查看>>
    MySQL I 有福啦,窗口函数大大提高了取数的效率!
    查看>>
    mysql id自动增长 初始值 Mysql重置auto_increment初始值
    查看>>