1.Mysql 架构原理、基础库表sql语句

  • 体系结构:C/S(客户端/服务端)模型架构

  • mysqld程序结构:

  • 一条SQL语句的执行过程:

    • 1.连接层:

      • 客户端通过TCP/IP、套接字等方式与服务端进行连接。
      • 当有哭护短发起连接时,需要携带主机名、用户名、密码,服务端进行验证
      • 连接层的作用:

        • 提供连接协议:TCP/IP、SOCKET(套接字)
        • 提供验证:用户、密码、TP、SOCKET
        • 提供专用连接线程:接收用户SQL,返回结果通过以下语句可以查看到连接线程基本情况:
          • mysql> show processlist;
    • 2.SQL层:

      • 建立连接后,当输入增删改查等语句时,需要进行下一层的处理也就是SQL层
      • 处理过程与作用:

        • 1.接收上层传送的SQL语句
        • 2.语法验证模块,验证语句的语法
        • 3.语义检查:判断SQL语句的类型

          • DDL:数据定义语言 create drop alter
          • DCL:数据控制语言 grant revoke
          • DML:数据操作语言insert delete update
          • DQL:数据查询语言select
        • 4.权限检查,检查用户是否有权限
        • 5.解析器:对语句执行前,进行预处理,生成解析树(执行计划),说白了就是生成多种执行方案
        • 6.优化器:根据解析器得出的多种执行计划,进行判断,选择最优的执行计划
        • 7.执行器:根据最优执行计划,执行SQL语句,产生执行结果,放在磁盘上
        • 8.提供查询缓存(默认是没有开启的),会使用redis tair替代查询缓存
        • 9.提供日志记录(日志管理章节):binlog,默认是没有开启的
      • 存储引擎层(类似于linux中的文件系统)

        • 负责根据SQL层的执行结果,从磁盘中拿数据以及写数据,也都是由存储引擎层来处理。
        • 将16进制的磁盘数据,交给SQL结构化化成表
        • 连接层的专用线程返回给用户
    • 有关库的SQL语句:
      • 库名和库属性:

        • 创建库并指定字符编码和校对集:
          • create database wordpress default charset utf8mb4 collate utf8mb4_bin;
        • 查看建库语句:
          • show create database wordpress;
        • 查看所有库:
          • show databases;
        • 切换库:
          • use wordpress;
    • 有关表的SQL语句:

      • 表名、表属性、列:列名(字段),列属性(数据类型,约束等)、数据行(记录)
      • 创建表,指定列和数据类型:
        • create table t1 (id int primary key,name varchar(20));
      • 插入数据,建议多行一起插入,减少日志量:
        • insert into t1 values (1,'zhangsan'),(2,'lisi'),(3,'wangwu');
      • 查看表所有数据:
        • select * from t1;
      • 分析表结构:
        • desc t1;
      • 查看创表语句:
        • show create table t1;
    • 有关用户、权限的SQL语句:

      • 查看mysql所有用户:

        • select user,host from mysql.user;
        • 创建用户:create user lisi@'%' identified by '1234.com';
        • 查看用户:select user ,host ,authentication_string from mysql.user;
        • 更改用户权限或密码:alter user lisi@'192.168.1.%' identified by '456';
        • 删除用户:drop user lisi@'192.168.1.%';
      • 权限管理:

        • grant all on wordpress.* to wordpress@'192.168.1.%' identified by '123';
        • 创建一个用户对app库下的所有表拥有增删改查权限:
          • grant select ,update,insert,delete on app.* to app@'192.168.8.%' identified by '1234.com';
        • 查看权限:show grants for app@'192.168.8.%';
        • 回收权限:
          • 将删除权限回收:revoke delete on app.* from app@'192.168.8.%';
相关推荐
失心疯_202332 分钟前
006.MySQL_查询数据
数据库·sql·mysql·关系型数据库·sqlyog·mysql教程·查询语句
环能jvav大师40 分钟前
基于R语言的统计分析基础:使用SQL语句操作数据集
开发语言·数据库·sql·数据分析·r语言·sqlite
楠枬1 小时前
MySQL数据的增删改查(一)
数据库·mysql
hayhead2 小时前
高频 SQL 50 题(基础版)| 626. 换座位
sql·力扣
阿华的代码王国3 小时前
MySQL ------- 索引(B树B+树)
数据库·mysql
liupenglove3 小时前
golang操作mysql利器-gorm
mysql·golang
Darling_003 小时前
LeetCode_sql_day28(1767.寻找没有被执行的任务对)
sql·算法·leetcode
zxrhhm4 小时前
SQLServer TOP(Transact-SQL)
sql·sqlserver
叫我:松哥4 小时前
基于Python flask的医院管理学院,医生能够增加/删除/修改/删除病人的数据信息,有可视化分析
javascript·后端·python·mysql·信息可视化·flask·bootstrap
单字叶4 小时前
MySQL数据库
数据库·mysql