• MySQL学习大纲


    了解 MySQL 的基础知识和命令是使用此数据库的前提。以下是一些必须了解的 MySQL 概念和命令,包括基础的 CRUD(创建,读取,更新,删除)操作,以及一些高级功能:

    1. 安装和启动

    • 命令
      sudo apt-get install mysql-server
      sudo service mysql start
      
      • 1
      • 2
    • 解析
      这些命令在基于 Debian 的系统上安装 MySQL 服务器,并启动服务。

    2. 登录数据库

    • 命令
      mysql -u root -p
      
      • 1
    • 解析
      使用 root 用户登录 MySQL 数据库。系统将提示您输入密码。

    3. 数据库操作

    a) 创建数据库
    • 命令
      CREATE DATABASE mydatabase;
      
      • 1
    • 解析
      创建一个名为 “mydatabase”的新数据库。
    b) 选择数据库
    • 命令
      USE mydatabase;
      
      • 1
    • 解析
      选择先前创建的 “mydatabase” 数据库以进行进一步操作。
    c) 查看所有数据库
    • 命令
      SHOW DATABASES;
      
      • 1
    • 解析
      列出服务器上存在的所有数据库。

    4. 表操作

    a) 创建表
    • 命令
      CREATE TABLE users (
          id INT AUTO_INCREMENT PRIMARY KEY,
          name VARCHAR(100),
          email VARCHAR(100)
      );
      
      • 1
      • 2
      • 3
      • 4
      • 5
    • 解析
      在当前数据库中创建一个名为“users”的新表,包含 id、name 和 email 列。
    b) 查看所有表
    • 命令
      SHOW TABLES;
      
      • 1
    • 解析
      列出当前数据库中存在的所有表。
    c) 查看表结构
    • 命令
      DESCRIBE users;
      
      • 1
    • 解析
      显示“users”表的结构,包括列名、数据类型等。

    5. 记录操作

    a) 插入记录
    • 命令
      INSERT INTO users (name, email) VALUES ('John Doe', 'john.doe@example.com');
      
      • 1
    • 解析
      在“users”表中插入一条新记录。
    b) 查询记录
    • 命令
      SELECT * FROM users;
      
      • 1
    • 解析
      从“users”表中检索所有记录。
    c) 更新记录
    • 命令
      UPDATE users SET email = 'john.new@example.com' WHERE name = 'John Doe';
      
      • 1
    • 解析
      更新“users”表中特定记录的 email 地址。
    d) 删除记录
    • 命令
      DELETE FROM users WHERE name = 'John Doe';
      
      • 1
    • 解析
      从“users”表中删除特定的记录。

    6. 索引

    • 命令
      CREATE INDEX idx_users_name ON users(name);
      
      • 1
    • 解析
      在“users”表的 name 列上创建索引,以加快查询速度。

    7. 用户和权限

    a) 创建用户
    • 命令
      CREATE USER 'newuser'@'localhost' IDENTIFIED BY 'password';
      
      • 1
    • 解析
      创建一个新的 MySQL 用户并设置密码。
    b) 授予权限
    • 命令
      GRANT ALL PRIVILEGES ON mydatabase.* TO 'newuser'@'localhost';
      
      • 1
    • 解析
      授予新用户访问特定数据库的所有权限。

    8. 备份与恢复

    a) 备份数据库
    • 命令
      mysqldump -u root -p mydatabase > mydatabase.sql
      
      • 1
    • 解析
      将特定数据库备份到 SQL 文件。
    b) 恢复数据库
    • 命令
      mysql -u root -p mydatabase < mydatabase.sql
      
      • 1
    • 解析
      从 SQL 文件恢复数据库。

    9. 优化与维护

    a) 优化表
    • 命令
      OPTIMIZE TABLE users;
      
      • 1
    • 解析
      优化特定表以回收未使用的空间,并改善性能。
    b) 检查表
    • 命令
      CHECK TABLE users;
      
      • 1
    • 解析
      检查表的完整性,查找错误。

    这些基础知识和命令是入门 MySQL 的基础,但 MySQL 还有更多高级功能和优化技术,值得深入学习和了解。

    1. 分区表

    • 命令
      CREATE TABLE employees (
          id INT,
          name VARCHAR(50),
          hired DATE
      )
      PARTITION BY RANGE( YEAR(hired) ) (
          PARTITION p0 VALUES LESS THAN (1991),
          PARTITION p1 VALUES LESS THAN (1999),
          PARTITION p2 VALUES LESS THAN MAXVALUE
      );
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
    • 解析
      这个命令创建了一个分区表,根据“hired”列的年份值将数据分成不同的部分。这可以优化查询性能,尤其是在处理大量数据时。

    2. 子查询

    • 命令
      SELECT name FROM employees WHERE id IN (SELECT id FROM department WHERE name = 'HR');
      
      • 1
    • 解析
      这个命令执行了一个子查询,查找属于HR部门的所有员工的名字。子查询可以用于构建更复杂的查询。

    3. 视图

    • 命令
      CREATE VIEW hr_employees AS SELECT name FROM employees WHERE department = 'HR';
      
      • 1
    • 解析
      这个命令创建了一个视图,列出了所有属于HR部门的员工。视图是基于SQL查询的虚拟表,可用于简化复杂的查询。

    4. 存储过程

    • 命令
      DELIMITER //
      CREATE PROCEDURE GetEmployeeCount(IN dept_name VARCHAR(50), OUT count INT)
      BEGIN
          SELECT COUNT(*) INTO count FROM employees WHERE department = dept_name;
      END //
      DELIMITER ;
      CALL GetEmployeeCount('HR', @count);
      SELECT @count;
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
    • 解析
      这个命令定义了一个存储过程,用于获取特定部门的员工数量。存储过程是存储在数据库中的一组SQL语句,可以通过单个调用来执行。

    5. 触发器

    • 命令
      DELIMITER //
      CREATE TRIGGER before_employee_update
      BEFORE UPDATE ON employees
      FOR EACH ROW
      BEGIN
          SET NEW.updated_at = NOW();
      END; //
      DELIMITER ;
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
    • 解析
      这个命令创建了一个触发器,在每次更新“employees”表之前自动设置“updated_at”字段。触发器可以用于自动执行数据库操作。

    6. 事务

    • 命令
      START TRANSACTION;
      UPDATE account SET balance = balance - 100 WHERE name = 'John';
      UPDATE account SET balance = balance + 100 WHERE name = 'Jane';
      COMMIT;
      
      • 1
      • 2
      • 3
      • 4
    • 解析
      这个命令执行了一个事务,将一笔金额从John的账户转到Jane的账户。事务可以确保一组操作的原子性,要么全部成功,要么全部失败。

    7. 索引优化

    • 命令
      ALTER TABLE employees ADD INDEX idx_department (department);
      
      • 1
    • 解析
      通过为经常用于搜索和排序的列添加索引,可以显著提高查询性能。

    8. 查询缓存

    • 解析
      MySQL有内建的查询缓存。当启用查询缓存时,MySQL会存储SELECT查询的结果,当收到完全相同的查询时,它会从缓存中直接返回结果,而不是重新执行查询。

    9. 性能分析

    • 命令
      EXPLAIN SELECT * FROM employees WHERE department = 'HR';
      
      • 1
    • 解析
      使用EXPLAIN命令,可以看到MySQL是如何执行查询的,这对于优化查询性能非常有用。

    10. 数据库归档

    • 解析
      为了提高性能和管理大量数据,您可以定期归档旧的数据记录。

    11. 全文搜索

    • 命令
      ALTER TABLE articles ADD FULLTEXT(title, content);
      SELECT * FROM articles WHERE MATCH(title, content) AGAINST('keyword');
      
      • 1
      • 2
    • 解析
      MySQL 支持对 CHAR、VARCHAR 和 TEXT 列执行全文搜索。全文索引可用于快速查找包含特定单词或短语的记录。

    12. 外键和参照完整性

    • 命令
      ALTER TABLE orders ADD FOREIGN KEY (customer_id) REFERENCES customers(id);
      
      • 1
    • 解析
      外键用于确保表之间的数据完整性。在这个例子中,orders 表中的 customer_id 列被定义为 customers 表中 id 列的外键。

    13. 事件调度器

    • 命令
      SET GLOBAL event_scheduler = ON;
      CREATE EVENT myevent
      ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 HOUR
      DO
        UPDATE mytable SET mycolumn = mycolumn + 1;
      
      • 1
      • 2
      • 3
      • 4
      • 5
    • 解析
      事件调度器用于定时执行数据库命令或操作。这个例子中,一个事件被创建来在一个小时后更新表中的一个列。

    14. 表空间和分区管理

    • 解析
      表空间允许您管理数据库的物理结构。分区可以将一个物理表分割成多个小的子表,这可以优化大表的查询性能。

    15. 在线DDL操作

    • 命令
      ALTER TABLE tablename ADD COLUMN newcol INT, ALGORITHM=INPLACE, LOCK=NONE;
      
      • 1
    • 解析
      在线 DDL 操作允许您在不阻塞对现有表的访问的情况下,修改表的结构。

    16. 窗口函数

    • 命令
      SELECT name, salary, 
             AVG(salary) OVER(PARTITION BY department) as avg_salary_department
      FROM employees;
      
      • 1
      • 2
      • 3
    • 解析
      窗口函数允许您在每行的基础上执行计算,这在计算聚合值时特别有用,例如每个部门的平均工资。

    17. Common Table Expressions (CTE)

    • 命令
      WITH cte_name AS (
          SELECT department, AVG(salary) as avg_salary
          FROM employees
          GROUP BY department
      )
      SELECT * FROM cte_name;
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
    • 解析
      CTE 提供了定义临时结果集的方法,这个结果集可以在一个 SELECT、INSERT、UPDATE 或 DELETE 查询中引用。

    18. 优化器

    • 解析
      MySQL 查询优化器会自动选择最有效的查询执行计划。您可以使用提示和索引来影响优化器的决策,以及使用 EXPLAIN 命令来查看优化器的选择。

    19. 资源组

    • 命令
      CREATE RESOURCE GROUP rg1
      TYPE = USER
      VCPU = 2,4
      PRIORITY = 10;
      
      • 1
      • 2
      • 3
      • 4
    • 解析
      资源组允许您将系统资源分配给特定的查询,以便在多租户环境中管理工作负载。

    这些是 MySQL 的一些额外高级功能和优化技术,这些功能和技术有助于高效地管理和查询数据库。

  • 相关阅读:
    java计算机毕业设计开放式实验室预约系统源码+mysql数据库+系统+lw文档+部署
    Python爬虫实战:抓取和分析新闻数据与舆情分析
    第七章 操作位和位串(三)
    【Redis】字符串sds
    应用程序主题生成很简单!界面控件DevExtreme有现成的主题生成器
    合成孔径雷达地面运动目标检测技术研究——基于概率图(Matlab代码实现)
    解决 Python requests 库中 SSL 错误转换为 Timeouts 问题
    【JAVA】String类
    聊聊对RPC的理解
    CIRIUM(睿思誉)逐渐成为航空公司二氧化碳排放报告的标准
  • 原文地址:https://blog.csdn.net/m0_57021623/article/details/133221173