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 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
曾经的三心草2 小时前
redis-9-哨兵
数据库·redis·bootstrap
明哥说编程2 小时前
Dataverse自定义表查询优化:D365集成大数据量提速实战【索引配置】
数据库·查询优化·dataverse·dataverse自定义表·索引配置·d365集成·大数据量提速
xiaowu0802 小时前
C# 拆解 “显式接口实现 + 子类强类型扩展” 的设计思想
数据库·oracle
讯方洋哥2 小时前
HarmonyOS App开发——关系型数据库应用App开发
数据库·harmonyos
惊讶的猫3 小时前
Redis持久化介绍
数据库·redis·缓存
Apple_羊先森3 小时前
ORACLE数据库巡检SQL脚本--19、磁盘读次数最高的前5条SQL语句
数据库·sql·oracle
全栈前端老曹4 小时前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈
神梦流4 小时前
ops-math 算子库的扩展能力:高精度与复数运算的硬件映射策略
服务器·数据库