常用的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;
相关推荐
czlczl200209252 分钟前
MySQL InnoDB 加锁全解析
数据库·mysql
lifewange4 分钟前
SQL Server、MySQL、Oracle 核心区别对比
数据库·mysql·oracle
彳亍1016 分钟前
mysql主从复制和双主复制有什么区别_mysql架构对比
jvm·数据库·python
a7963lin6 分钟前
MySQL数据库提示表损坏怎么修复_使用REPAIR TABLE修复方案
jvm·数据库·python
dFObBIMmai7 分钟前
如何撤销PUBLIC的危险权限_REVOKE EXECUTE ON UTL_FILE
jvm·数据库·python
2501_901200538 分钟前
CSS如何优化移动端CSS选择器性能_遵循BEM规范避免过长嵌套
jvm·数据库·python
ㄟ留恋さ寂寞9 分钟前
如何用事务 Transaction 确保 IndexedDB 多表操作的安全性
jvm·数据库·python
m0_495496419 分钟前
html标签怎样表示强调_em和i标签语义差异说明【操作】
jvm·数据库·python
weixin_4597539410 分钟前
如何防止SQL脏数据写入_利用触发器实现强一致性校验
jvm·数据库·python
老纪12 分钟前
CSS如何快速预览CSS颜色值效果_结合浏览器开发者工具取色板
jvm·数据库·python