首页 > 数据库 >mysql 常用知识点总结

mysql 常用知识点总结

时间:2024-09-16 14:13:57浏览次数:8  
标签:总结 知识点 name 示例 column students mysql table SELECT

MySQL 是一种广泛使用的关系型数据库管理系统(RDBMS),它基于结构化查询语言(SQL)。了解 MySQL 的语法对数据库管理和操作非常重要。以下是 MySQL 语法的详细完整解释,涵盖基本概念、创建表、查询、修改数据等内容。

1. 基础概念

  • 数据库 (Database): 数据库是存储数据的容器,里面可以包含多个表。
  • 表 (Table): 表是数据库中的核心元素,包含行(记录)和列(字段)。
  • 行 (Row): 一行数据代表表中的一条记录。
  • 列 (Column): 列是数据的属性,每个列都有一个特定的数据类型。
  • 数据类型 (Data Types): 定义列中数据的类型,如整数、浮点数、字符串、日期等。

2. 常见数据类型

数据类型 描述
INT 整数
FLOAT 浮点数
VARCHAR 变长字符串
CHAR 固定长度字符串
TEXT 大文本
DATE 日期(格式:YYYY-MM-DD)
DATETIME 日期和时间(格式:YYYY-MM-DD HH:MM:SS)

3. 数据库管理

  • 创建数据库

    CREATE DATABASE db_name;
    
    • db_name: 数据库名称。
  • 选择数据库

    USE db_name;
    
  • 查看现有数据库

    SHOW DATABASES;
    
  • 删除数据库

    DROP DATABASE db_name;
    

4. 表操作

  • 创建表

    CREATE TABLE table_name (
      column_name1 data_type constraints,
      column_name2 data_type constraints,
      ...
    );
    
    • table_name: 表的名称。
    • data_type: 列的数据类型。
    • constraints: 列的约束,如 PRIMARY KEYNOT NULL 等。

    示例:

    CREATE TABLE students (
      id INT PRIMARY KEY,
      name VARCHAR(50) NOT NULL,
      age INT,
      enrollment_date DATE
    );
    
  • 查看表结构

    DESCRIBE table_name;
    
  • 删除表

    DROP TABLE table_name;
    
  • 修改表结构

    • 添加新列:
      ALTER TABLE table_name ADD new_column_name data_type;
      
    • 修改列类型:
      ALTER TABLE table_name MODIFY column_name new_data_type;
      
    • 删除列:
      ALTER TABLE table_name DROP COLUMN column_name;
      

5. 数据操作

5.1 插入数据

INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...);

示例:

INSERT INTO students (id, name, age, enrollment_date) VALUES (1, 'John Doe', 20, '2023-09-01');

5.2 查询数据

  • 基本查询

    SELECT column1, column2, ... FROM table_name;
    

    示例:

    SELECT name, age FROM students;
    
  • 查询所有列

    SELECT * FROM table_name;
    
  • 使用条件过滤查询

    SELECT column1, column2, ... FROM table_name WHERE condition;
    

    示例:

    SELECT * FROM students WHERE age > 18;
    
  • 排序

    SELECT * FROM table_name ORDER BY column1 [ASC|DESC];
    

    示例:

    SELECT * FROM students ORDER BY age DESC;
    
  • 限制查询结果

    SELECT * FROM table_name LIMIT number;
    

    示例:

    SELECT * FROM students LIMIT 5;
    
  • 聚合函数

    • COUNT():返回记录数
    • SUM():返回总和
    • AVG():返回平均值
    • MIN():返回最小值
    • MAX():返回最大值

    示例:

    SELECT COUNT(*) FROM students;
    

5.3 更新数据

UPDATE table_name SET column1 = value1, column2 = value2 WHERE condition;

示例:

UPDATE students SET age = 21 WHERE id = 1;

5.4 删除数据

DELETE FROM table_name WHERE condition;

示例:

DELETE FROM students WHERE id = 1;

6. 连接 (JOIN) 操作

  • 内连接 (INNER JOIN): 返回两个表中匹配的记录。

    SELECT columns FROM table1 INNER JOIN table2 ON table1.column = table2.column;
    
  • 左连接 (LEFT JOIN): 返回左表中的所有记录,即使右表中没有匹配。

    SELECT columns FROM table1 LEFT JOIN table2 ON table1.column = table2.column;
    
  • 右连接 (RIGHT JOIN): 返回右表中的所有记录,即使左表中没有匹配。

    SELECT columns FROM table1 RIGHT JOIN table2 ON table1.column = table2.column;
    

7. 索引 (Index)

索引用于提高查询速度。

  • 创建索引

    CREATE INDEX index_name ON table_name (column_name);
    
  • 删除索引

    DROP INDEX index_name ON table_name;
    

8. 事务 (Transaction)

事务确保一组 SQL 操作要么全部执行,要么全部不执行。

  • 开始事务

    START TRANSACTION;
    
  • 提交事务

    COMMIT;
    
  • 回滚事务

    ROLLBACK;
    

9. 视图 (View)

视图是基于 SQL 查询的虚拟表。

  • 创建视图

    CREATE VIEW view_name AS SELECT columns FROM table_name WHERE condition;
    
  • 删除视图

    DROP VIEW view_name;
    

10. 存储过程 (Stored Procedure)

存储过程是一组预编译的 SQL 语句,封装起来可以复用。

  • 创建存储过程

    CREATE PROCEDURE procedure_name (parameters)
    BEGIN
      SQL_statements;
    END;
    
  • 调用存储过程

    CALL procedure_name(parameters);
    
  • 删除存储过程

    DROP PROCEDURE procedure_name;
    

11. 触发器 (Trigger)

触发器在某个事件(如插入、更新或删除)发生时自动执行。

  • 创建触发器

    CREATE TRIGGER trigger_name BEFORE|AFTER INSERT|UPDATE|DELETE ON table_name
    FOR EACH ROW
    BEGIN
      SQL_statements;
    END;
    
  • 删除触发器

    DROP TRIGGER trigger_name;
    

12. 权限管理

  • 创建用户

    CREATE USER 'username'@'host' IDENTIFIED BY 'password';
    
  • 赋予权限

    GRANT ALL PRIVILEGES ON database_name.* TO 'username'@'host';
    
  • 撤销权限

    REVOKE ALL PRIVILEGES ON database_name.* FROM 'username'@'host';
    
  • 删除用户

    DROP USER 'username'@'host';
    

13. 常用工具

  • EXPLAIN: 查看查询的执行计划。

    EXPLAIN SELECT * FROM table_name;
    
  • SHOW PROCESSLIST: 查看当前运行的 SQL 查询。

    SHOW PROCESSLIST;
    

这是 MySQL 的完整语法概述,适用于基本数据库操作、数据查询、表结构管理、索引、事务、存储过程等内容。通过学习和使用这些语法,能够有效管理和查询数据库。

标签:总结,知识点,name,示例,column,students,mysql,table,SELECT
From: https://www.cnblogs.com/xxctx/p/18416244

相关文章

  • 2024.9.16 上午 总结(考 DS)
    T1我的做法:合并->并查集。类似建Kruskal重构树。询问跑LCA。注意并查集合并要把两个根都变成一个新点的儿子,而不是把一个作为另一个的儿子。(可能类似建[边](?)Kruskal重构树)要特判询问时\(x=y\)的情况(好像是输出\(0\))。lzh的做法:连出一棵树,边的边权是......
  • Mysql数据库的原理和应用
    第一章数据库概述一学习环境介绍1.Windows10/11非家庭版内存8g2.Vmwareworkstation16.03.LAMP--LinuxAparchemysqlPHPLNMP--LinuxnginxmysqlPHPWAMP--WindowsAparchemysqlPHPWNMP--WindowsnginxmysqlPHP注意:Windows是非客服端操作系统,而是服务器版......
  • MySQL8.0直方图详解
    1、什么是直方图MySQL8.0开始支持索引之外的数据分布统计信息可选项。它就是直方图(Histogram)。直方图通过估算查询谓词的选择率,以便选择合适的执行计划,也让SQL优化有了更多手段。在DB中,优化器负责将SQL转换为很多个不同的执行计划,然后从中选择一个最优的来实际执行。但是有时候优......
  • MySQL篇(运算符)(持续更新迭代)
    目录一、简介二、运算符使用1.算术运算符1.1.加法运算符1.2.减法运算符1.3.乘法与除法运算符1.4.求模(求余)运算符2.比较运算符2.1.等号运算符2.2.安全等于运算符2.3.不等于运算符2.4.空运算符2.5.非空运算符2.6.最小值运算符2.7.最大值运算符2.8.......
  • MySQL篇(高级字符串函数/正则表达式)(持续更新迭代)
    目录讲点一:高级字符串函数一、简介二、常见字符串函数1.CONCAT()2.SUBSTRING()3.LENGTH()4.REPLACE()5.TRIM()6.UPPER()7.LOWER()8.LEFT()9.RIGHT()10.INSTR()11.LENTH(str)讲点二:正则表达式一、简介二、语法1.字符类2.重复次数3.通配符4.......
  • mysql5.5源码主从复制搭建(以两台机器的单实例为例)
    mysql5.5源码主从复制搭建(以两台机器的单实例为例)如果对运维课程感兴趣,可以在b站上、csdn或微信视频号上搜索我的账号:运维实战课程,可以关注我,学习更多免费的运维实战技术视频项目1  配置mysql服务器的主从结构(开始时主从数据不一致时需要找到临界点的主从同步,主库初始......
  • 9.15 比赛总结
    突然想起来自己把比赛总结的好习惯忘掉了,所以现在重新拾起,故名曰《朝花夕拾》。T1出了个大阴间题看数据范围明显状压。很明显,\(a,b\)分成两部分处理。\(f_{s,i}\)表示状态为\(s\),\(a=i\)时的所有情况之和,还要计算\(num_{s,i}\)表示此时情况数。\(b\)直接递推模拟即可......
  • MYSQL面试系列-04
    MYSQL面试系列-0417.关于redolog和binlog的刷盘机制、redolog、undolog作用、GTID是做什么的?innodb_flush_log_at_trx_commit及sync_binlog参数意义双117.1innodb_flush_log_at_trx_commit该变量定义了InnoDB在每次事务提交时,如何处理未刷入(flush)的重做日志信息......
  • MySQL锁机制揭秘:从行锁到表锁,共享锁到排他锁,悲观锁到乐观锁的全面解读
    MySQL有哪些锁1、按照锁的粒度划分行锁是最低粒度的的锁,锁住指定行的数据,加锁的开销较大,加锁较慢,可能会出现死锁的情况,锁的竞争度会较低,并发度相对较高。但是如果where条件里的字段没有加索引,则加的行锁会自动升级为表锁,因为行锁是基于索引去进行操作的,所以想要加行锁,就......
  • 一文看完MySQL 9.0新特性!
    本文总结自MySQL8.4以来,在MySQL9.0中新增、废弃、更改和删除的内容。MySQL9.0中新增或更改的功能。1MySQL9.0新特性1VECTOR类型支持MySQL9.0支持VECTOR列类型。向量是一个数据结构,它由条目列表(4字节浮点值)组成,可以表示为二进制字符串值或列表格式字符串。VECT......