常用的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;
相关推荐
m0_377618235 分钟前
c++如何将双精度浮点数以科学计数法写入文件_scientific标志【详解】
jvm·数据库·python
weixin_424999368 分钟前
如何检测SQL注入风险_利用模糊测试技术发现漏洞
jvm·数据库·python
2301_7751481511 分钟前
如何用正则具名捕获组 (-) 提升复杂数据的提取效率
jvm·数据库·python
2501_9142459316 分钟前
Go语言如何在VSCode中开发_Go语言VSCode配置教程【避坑】.txt
jvm·数据库·python
2301_7826591819 分钟前
MongoDB如果有一个分片完全宕机集群还能用吗_受影响数据的不可读与分片隔离感知
jvm·数据库·python
justjinji20 分钟前
JavaScript中严格模式use-strict对引擎解析的辅助
jvm·数据库·python
Absurd58722 分钟前
CSS如何使用-default获取默认选项样式_通过状态伪类突出预选表单项
jvm·数据库·python
风吹迎面入袖凉27 分钟前
【Redis】Redis缓存击穿
数据库·redis·缓存
weixin_4585801230 分钟前
CSS如何让flex布局支持老版本浏览器_添加-webkit-前缀与兼容性写法
jvm·数据库·python
Shorasul35 分钟前
CSS viewport单位在旧移动端支持不佳_利用固定像素值与rem配合
jvm·数据库·python