mysql常用语句

MySQL常用命令技术文章大纲

数据库操作
  • 创建数据库
    CREATE DATABASE database_name;
  • 删除数据库
    DROP DATABASE database_name;
  • 查看所有数据库
    SHOW DATABASES;
  • 使用数据库
    USE database_name;
表操作
  • 创建表

    sql 复制代码
    CREATE TABLE table_name (
        column1 datatype constraints,
        column2 datatype constraints,
        ...
    );
  • 删除表
    DROP TABLE table_name;

  • 查看表结构
    DESCRIBE table_name;SHOW COLUMNS FROM table_name;

  • 修改表结构

    sql 复制代码
    ALTER TABLE table_name 
    ADD column_name datatype;
  • 重命名表
    RENAME TABLE old_name TO new_name;

数据操作
  • 插入数据

    sql 复制代码
    INSERT INTO table_name (column1, column2, ...) 
    VALUES (value1, value2, ...);
  • 查询数据
    SELECT * FROM table_name;

  • 更新数据

    sql 复制代码
    UPDATE table_name 
    SET column1 = value1, column2 = value2 
    WHERE condition;
  • 删除数据
    DELETE FROM table_name WHERE condition;

索引操作
  • 创建索引
    CREATE INDEX index_name ON table_name (column_name);
  • 删除索引
    DROP INDEX index_name ON table_name;
用户与权限管理
  • 创建用户
    CREATE USER 'username'@'host' IDENTIFIED BY 'password';

  • 授予权限

    sql 复制代码
    GRANT permission_type ON database_name.table_name 
    TO 'username'@'host';
  • 撤销权限

    sql 复制代码
    REVOKE permission_type ON database_name.table_name 
    FROM 'username'@'host';
  • 删除用户
    DROP USER 'username'@'host';

备份与恢复
  • 导出数据库
    mysqldump -u username -p database_name > backup.sql
  • 导入数据库
    mysql -u username -p database_name < backup.sql
事务与锁
  • 开启事务
    START TRANSACTION;
  • 提交事务
    COMMIT;
  • 回滚事务
    ROLLBACK;
性能优化
  • 查看执行计划
    EXPLAIN SELECT * FROM table_name;
  • 优化表
    OPTIMIZE TABLE table_name;

联表查询的基本概念

联表查询(Join)用于从多个表中组合数据,基于表之间的关联字段。常见的联表类型包括内连接(INNER JOIN)、左连接(LEFT JOIN)、右连接(RIGHT JOIN)和全连接(FULL JOIN)。

内连接(INNER JOIN)

内连接返回两个表中匹配的行。语法示例:

sql 复制代码
SELECT A.column1, B.column2
FROM TableA A
INNER JOIN TableB B ON A.key = B.key;

仅返回 TableATableBkey 字段匹配的行。

左连接(LEFT JOIN)

左连接返回左表的所有行,即使右表没有匹配。右表无匹配时填充 NULL。语法示例:

sql 复制代码
SELECT A.column1, B.column2
FROM TableA A
LEFT JOIN TableB B ON A.key = B.key;

右连接(RIGHT JOIN)

右连接返回右表的所有行,即使左表没有匹配。左表无匹配时填充 NULL。语法示例:

sql 复制代码
SELECT A.column1, B.column2
FROM TableA A
RIGHT JOIN TableB B ON A.key = B.key;

全连接(FULL JOIN)

全连接返回左右表的所有行,无匹配时填充 NULL。语法示例:

sql 复制代码
SELECT A.column1, B.column2
FROM TableA A
FULL JOIN TableB B ON A.key = B.key;

自连接(Self Join)

自连接是表与自身的连接,通常用于层级数据查询。语法示例:

sql 复制代码
SELECT A.column1, B.column2
FROM Table A, Table B
WHERE A.key = B.foreign_key;

多表连接

可以连接多个表,语法示例:

sql 复制代码
SELECT A.column1, B.column2, C.column3
FROM TableA A
INNER JOIN TableB B ON A.key = B.key
INNER JOIN TableC C ON B.key = C.key;

性能优化建议

  • 为连接字段创建索引。
  • 避免不必要的联表,仅选择需要的字段。
  • 使用 EXPLAIN 分析查询执行计划。

联表查询是数据库操作的核心功能,合理使用能高效整合多表数据。

  • 查看MySQL版本
    SELECT VERSION();
  • 查看当前用户
    SELECT USER();
  • 查看当前时间
    SELECT NOW();
相关推荐
镜舟科技2 小时前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend3 小时前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence6 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
先吃饱再说1 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils1 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend1 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶1 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung1 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql
parade岁月1 天前
MySQL JOIN解析:朴实无华但食之有味
数据库·后端
用户3169353811831 天前
MySQL服务无法启动问题解决全记录
数据库