常用的SQL语句(MySQL运行)

一、库操作(创建 / 查看 / 使用数据库)

  1. 建一个数据库
sql 复制代码
CREATE DATABASE mydb;
  1. 看有哪些库
sql 复制代码
SHOW DATABASES;

以下这四个是 MySQL 安装后自带的系统数据库,不是你自己创建的业务库,主要负责管理 MySQL 自身运行,一般不要手动修改或删除它们。

(1)information_schema

元数据字典:存储数据库、表、列等所有对象的结构信息,是虚拟库,只读,用于查询结构。

(2)mysql

核心系统库:存用户账号、权限、日志等核心配置,是 MySQL 正常运行的基础,别直接改表。

(3)performance_schema

性能监控库:收集服务器运行时性能数据(慢查询、资源占用等),用于调优和故障排查。

(4)sys

易用封装库:对前两个系统库做了视图封装,让性能数据更易读,简化运维查询。

  1. 进入这个库
sql 复制代码
USE mydb;
  1. 删除库
sql 复制代码
DROP DATABASE mydb;

二、表操作(建表 / 看表 / 删表)

  1. 建一张最简单的表
sql 复制代码
CREATE TABLE student(
  id INT PRIMARY KEY AUTO_INCREMENT,
  name VARCHAR(20),
  age INT
);
  1. 看有哪些表
sql 复制代码
SHOW TABLES;
  1. 看表结构
sql 复制代码
DESC student;
  1. 删除表
sql 复制代码
DROP TABLE student;

三、增(往表里加数据)INSERT

  1. 加一条数据
sql 复制代码
INSERT INTO student(name,age) VALUES('沈长泽',19);
  1. 一次加多条
sql 复制代码
INSERT INTO student(name,age) VALUES
('单鸣',18),
('白新羽',20);

四、查(看数据)SELECT

  1. 查全部
sql 复制代码
SELECT * FROM student;
  1. 只查名字
sql 复制代码
SELECT name FROM student;
  1. 条件查:年龄 = 18
sql 复制代码
SELECT * FROM student WHERE age=18;
  1. 模糊查:名字带 "沈
sql 复制代码
SELECT * FROM student WHERE name LIKE '%沈%';
  1. 排序:按年龄从大到小(ASC为升序,DESC为降序)
sql 复制代码
SELECT * FROM student ORDER BY age DESC;

五、改(更新数据)UPDATE

把单鸣的年龄改成 20:一定要加 WHERE,不然全表被改

sql 复制代码
UPDATE student SET age=20 WHERE name='单鸣';

六、删(删除数据)DELETE

删年龄 = 20 的

sql 复制代码
DELETE FROM student WHERE age=20;

七、数据分析常用

  1. 统计一共多少人
sql 复制代码
SELECT COUNT(*) FROM student;
  1. 求平均年龄
sql 复制代码
SELECT AVG(age) FROM student;
  1. 最大年龄(最小年龄用MIN)
sql 复制代码
SELECT MAX(age) FROM student;
  1. 年龄总和
sql 复制代码
SELECT SUM(age) FROM student;
  1. 按年龄分组统计
sql 复制代码
SELECT age, COUNT(*) FROM student GROUP BY age;

八、用户 / 账户操作(MySQL 管理员常用)

  1. 看当前用户
sql 复制代码
SELECT USER();
  1. 创建新用户
sql 复制代码
CREATE USER 'testuser'@'localhost' IDENTIFIED BY '123456';
  1. 给这个用户所有权限
sql 复制代码
GRANT ALL ON *.* TO 'testuser'@'localhost';
  1. 刷新权限
sql 复制代码
FLUSH PRIVILEGES;
  1. 删除用户
sql 复制代码
DROP USER 'testuser'@'localhost';

九、最简单的全流程实战

sql 复制代码
CREATE DATABASE test;
USE test;

CREATE TABLE user(
  id INT PRIMARY KEY AUTO_INCREMENT,
  name VARCHAR(20),
  score INT
);

INSERT INTO user(name,score) VALUES('小明',90),('小红',85),('小刚',99);

SELECT * FROM user;
SELECT AVG(score) FROM user;
SELECT MAX(score) FROM user;

UPDATE user SET score=100 WHERE name='小明';

DELETE FROM user WHERE score<90;
相关推荐
Nturmoils7 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波11 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
Jim6001 天前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
GreatSQL1 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
倔强的石头_1 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_4 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横4 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二4 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
冬奇Lab5 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm