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();
相关推荐
Flying pigs~~5 小时前
RAG智慧问答项目
数据库·人工智能·缓存·微调·知识库·rag
misL NITL6 小时前
mysql之如何获知版本
数据库·mysql
许彰午6 小时前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
2401_832365527 小时前
JavaScript中rest参数(...args)取代arguments的优势
jvm·数据库·python
2301_779622418 小时前
Go语言怎么用信号量控制并发_Go语言semaphore信号量教程【入门】
jvm·数据库·python
2301_766283448 小时前
c++如何将控制台输出保存到文件_cout重定向到txt【详解】
jvm·数据库·python
北极的冰箱8 小时前
MySQL Ver 8.0.41 for macos14.7密码遗忘
数据库·mysql
XDH_CS8 小时前
MySQL 8.0 安装与 MySQL Workbench 使用全流程(超详细教程)
开发语言·数据库·mysql
秋99 小时前
MySQL 8.0.46 全平台安装与配置详解(Windows/Linux/macOS)
linux·windows·mysql
treacle田9 小时前
达梦数据库-统计信息收集-记录
数据库·达梦数据库统计信息收集