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();
相关推荐
廿一夏14 小时前
MySql存储引擎与索引
数据库·sql·mysql
lzhdim16 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室17 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)17 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
敲个大西瓜17 小时前
Java项目常用数据归档方式
mysql
YOU OU18 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng19 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
kyriewen19 小时前
面试官让我查各部门工资最高的员工,我用AI三秒写出窗口函数,他愣了
后端·mysql·面试
小码工作室19 小时前
使用 HAVING 进行 MySQL 集合筛选
mysql
罗超驿20 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试