• MYSQL数据库学习


    从现在开始我是一个MYSQL学习者,接下来的日子我将用几天的时间学习MYSQL数据库的用法,本文章持续更新
    ps



    基础阶段

    基本概念
    数据库:存储数据的仓库
    数据库管理系统:操纵和管理数据库的大型软件
    SQL:操纵关系型数据库的编程语言,是一种标准

    在这里插入图片描述ps:一句话通过表来存储数据的就是关系型数据库
    在这里插入图片描述在这里插入图片描述在这里插入图片描述

    基本操作
    在这里插入图片描述ps:定操查控
    在这里插入图片描述在这里插入图片描述在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述
    在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述ps:所有的null值不参与运算
    在这里插入图片描述在这里插入图片描述在这里插入图片描述
    在这里插入图片描述在这里插入图片描述ps:如查询前五个人员,那么就是分页,limit永远放语句的最后

    在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述ps:select 函数(参数)
    在这里插入图片描述在这里插入图片描述在这里插入图片描述
    在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

    约束

    在这里插入图片描述ps:约束是作用于表中字段上的,可以在创建,修改表时添加约束

    在这里插入图片描述
    在这里插入图片描述
    ps:黄主蓝外,外键保证数据的一致性和完整性

    在这里插入图片描述
    在这里插入图片描述

    多表查询

    在这里插入图片描述

    在这里插入图片描述
    在这里插入图片描述在这里插入图片描述
    在这里插入图片描述在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    PS:左右可以互换

    在这里插入图片描述PS:自己连接自己,比如一个员工表查询自己的领导,同时领导也属于公司的员工

    PS:左右连接的好处在于可以把对应值为null的数据也展现出来
    在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述在这里插入图片描述在这里插入图片描述

    事务

    在这里插入图片描述方式一
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    方式二
    在这里插入图片描述
    在这里插入图片描述

    在这里插入图片描述在这里插入图片描述
    PS:从上往下性能降低

    在这里插入图片描述

    进阶阶段

    存储引擎

    在这里插入图片描述在这里插入图片描述

    在这里插入图片描述PS:默认InnoDB引擎

    在这里插入图片描述在这里插入图片描述PS:每一个表都对应着一个ibd文件,存储着表结构和数据

    在这里插入图片描述

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述在这里插入图片描述

    在这里插入图片描述

    索引

    在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述
    在这里插入图片描述在这里插入图片描述

    在这里插入图片描述
    在这里插入图片描述

    在这里插入图片描述在这里插入图片描述
    在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

    在这里插入图片描述
    在这里插入图片描述PS:如果查询占大多数,那么性能优化就用慢查询日志,查询哪些select语句需要优化

    在这里插入图片描述
    PS:查询慢查询开启否
    在这里插入图片描述

    PS:还有要优化那种业务简单却相对较长的select语句,通过profile,
    在这里插入图片描述
    以上都是通过时间来粗略判定SQL语句的性能,要想真正的查看性能要用explain,查询是否使用索引等

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述PS:尽量使用大于等于或小于等于,否则后面的status的索引失效
    PS:索引使用如果不注意就会变成全表扫描,费时
    在这里插入图片描述在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述在这里插入图片描述PS:因为大多数都符合条件,那么还不如走全表扫描省时

    有了复合索引还能对字段再创建一个单列索引,这时候如果查询的时候可以用SQL提示来说明想用哪个索引来查询
    在这里插入图片描述
    PS:索引有单列索引和联合索引,分别就是一个和多个
    PS:第一个use只是建议,用不用是系统来评估的也可能不接受建议,第三条是强制使用

    在这里插入图片描述PS:在二级索引的叶子上就能找到ID,如果还要查询别的字段就需要在通过ID走聚集索引来找其他的字段,也就是回表查询数据,如果在聚集索引中用ID找*也数据覆盖索引的原则,不用回表
    PS:这里就可以多建立联合索引,这样就不用回表查询了

    在这里插入图片描述在这里插入图片描述

    在这里插入图片描述PS:自己平衡性能和大小来选择选前几个,降低索引体积提高查询效率

    在这里插入图片描述在这里插入图片描述
    PS:一定要考虑顺序,根据最左前缀法则最左边的一定要存在,上图中是phone

    在这里插入图片描述PS:如果数据量超过一百万就要考虑建立索引
    在这里插入图片描述在这里插入图片描述
    SQL优化

    在这里插入图片描述
    PS:避免频繁的事务的提交

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述在这里插入图片描述在这里插入图片描述
    在这里插入图片描述在这里插入图片描述在这里插入图片描述
    在这里插入图片描述PS:二级索引有很多并且叶子节点都是主键,如果主键太长会耗费大量的磁盘空间,像UUID这类生成的时候没有规矩很可能造成乱序插入

    在这里插入图片描述在这里插入图片描述
    PS:可以定义不同的排序规则,这样优化的时候可以也可以一个升序一个降序

    在这里插入图片描述在这里插入图片描述在这里插入图片描述PS:下面满足最左前缀法则,不用临时表,提高效率

    在这里插入图片描述在这里插入图片描述
    在这里插入图片描述在这里插入图片描述在这里插入图片描述
    PS:一旦升级为表锁那么并发性能就会降低
    视图

    在这里插入图片描述

    在这里插入图片描述
    PS:视图是一个虚拟的表,我们可以像操作表一样操作视图,也能增删改查
    在这里插入图片描述

    PS:cascaded级连,连带检查所有依赖的视图,没有加检查就不会检查

    在这里插入图片描述在这里插入图片描述PS:使用简单,定义为基本的视图然后可以进行视图依赖,简化操作,数据安全也就是可以用视图来让用户只能查询和修改他们所能见到的数据,数据独立指在SQL语句中可以用起别名的方法来屏蔽真实表的结构变化如名字变化带来的影响

    存储过程

    PS:每一次的SQL都代表一次网络请求

    在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述
    PS:默认session

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述在这里插入图片描述PS:有begin end的才用局部变量,否则就是用户自定义变量

    在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述
    在这里插入图片描述

    在这里插入图片描述PS:累加偶数

    在这里插入图片描述

    在这里插入图片描述
    在这里插入图片描述
    PS:要先声明局部变量再声明游标,那么如何结束循环?看下面

    在这里插入图片描述在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述在这里插入图片描述
    在这里插入图片描述

    PS:用的比较少,因为存储函数能完成的存储过程都能完成,并且存储函数强制必须有返回值,这是弊端

    在这里插入图片描述

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    在这里插入图片描述在这里插入图片描述在这里插入图片描述 INNODB引擎

    Mysql管理

    在这里插入图片描述

    自带四个数据库
    在这里插入图片描述在这里插入图片描述

    运维阶段

  • 相关阅读:
    峰会回顾 | 基于StarRocks,百草味如何通过数据赋能快消品行业
    决策树算法
    145 Linux 网络编程1 ,协议,C/S B/S ,OSI 7层模型,TCP/IP 4层模型,
    C++项目——云备份-①-项目介绍&环境搭建
    css-inpu边框
    学习MySQL-第六章
    校招秋招,性格和职业有关系吗?
    Python中的正则表达式(Regex匹配,贪婪匹配Greedy Matching)
    基于SSM的海鲜自助餐厅系统的设计与实现
    数据合并与对比
  • 原文地址:https://blog.csdn.net/nalidour/article/details/126141099