mysql 常用知识点总结

news/2024/10/5 22:45:47

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/60992.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

spring mvc详细讲解(前后端分离模式)

在前后端分离模式下,Spring MVC 的作用主要集中在处理后端的业务逻辑和 API 接口,而不再直接管理视图部分。也就是说,Spring MVC 的重点是如何处理客户端的请求并返回数据(通常以 JSON 或 XML 格式),而视图渲染交给前端框架(如 Vue.js、React 等)来完成。 下面是针对前…

关于API淘宝数据接口

在当今数字化商业时代,淘宝作为全球领先的电商平台,提供了丰富的API接口,使开发者能够高效地获取和管理电商数据。淘宝API接口不仅简化了与淘宝平台的交互,还为商家提供了强大的数据支持,帮助他们更好地分析市场趋势、优化店铺运营、提升用户体验。 淘宝API接口概述 淘宝A…

解决 Debian下 nvm ls-remote 列表只出现iojs版本的问题

1.进入 .bashrc 里vi ~/.bashrc2. o键新开一行增加下面内容export NVM_NODEJS_ORG_MIRROR=https://nodejs.org/dist 3.重载nvm配置source ~/.bashrc4.验证配置是否修改成功,如图则表示成功echo $NVM_NODEJS_ORG_MIRROR 5.再次查看可安装的node版本nvm ls-remote 备注:如果上…

Arrays类的使用

1.Arrays 在IDEA中有一个叫Arrays的类,它可以执行数组的一系列操作 2.Arrays.toString 该代码用于执行数组的打印,因为数组的打印用sout并不能输出出来(数组面向于对象),所以得用该代码输出3.Arrays.sort 将数组的数字从小到大排序4.Arrays.fill 将数组中的数字用其他数字…

跨界融合,GIS如何赋能游戏商业——以《黑神话:悟空》为例

在数字化时代,地理信息系统(GIS)技术正以其独特的空间分析和可视化能力,为游戏产业带来革命性的变革。《黑神话:悟空》作为中国首款3A级别的动作角色扮演游戏,不仅在游戏设计和技术上取得了突破,更在商业模式上展现了跨界融合的新路径。 1. GIS技术在游戏设计中的应用《…

如何在windows中设置系统代理

1、部署Gemini Gemini使用教程 - 迅捷网络[来送福利] - 博客园 (cnblogs.com) 2.左下角搜索设置或直接搜索代理 3.Gemini后台复制需要访问的那个设备IP 4.windows上设置代理 5.使用提示 1.不用的时候清取消此代理,避免你的网络都走此代理; 2.要走你本地电脑的网络的话,可以加…

常回家看看之house_of_cat

house_of_cat 前言: house of cat 这个利用手法和前面提到的 house of kiwi ,和 house of emma 利用的手法是一个链子,当程序无法通过main函数返回时候,或者程序不能显性调用exit函数的时候,我们可以通过 __malloc_assert 来刷新IO流,当然这个函数在2.35之后移除了刷新IO…

mysql-v8.x设置权限可以远程访问

PS:mysql-v8.4.2不支持原先的权限修改方式了,需要先创建再分配才行mysql -u root -p #先登录 SELECT user,host FROM mysql.user; #看下当前的权限 CREATE USER your_name@% IDENTIFIED BY your_password; #需要创建用户 grant all privileges on *.* to your_name@%; #分配权…