数据库学习(二)——MySQL语句

MySQL 语句分为:

语句类型作用关键字示例
数据查询(DQL)查询数据SELECT
数据操作(DML)插入、更新、删除数据INSERT, UPDATE, DELETE
数据定义(DDL)定义或修改表结构CREATE, ALTER, DROP
事务控制(TCL)控制事务执行BEGIN, COMMIT, ROLLBACK
权限控制(DCL)管理权限GRANT, REVOKE

一、查询语句(SELECT

用于从数据库中检索数据,是最常用的 SQL 语句。

语法结构:

SELECT column1, column2, ...
FROM table_name
WHERE condition
GROUP BY column
HAVING condition
ORDER BY column ASC|DESC
LIMIT offset, count;

关键部分解析:

  • SELECT指定查询哪些列,可以用 * 表示全部列;
  • FROM:指定查询的数据表
  • WHERE筛选符合条件的记录(过滤行);
  • GROUP BY:将结果按某列分组
  • HAVING:对分组后的结果进行条件过滤(区别于 WHERE,HAVING 针对聚合结果);
  • ORDER BY:对结果排序(升序 ASC降序 DESC);
  • LIMIT:限制返回的记录数及偏移量。

示例:

SELECT name, COUNT(*) AS orders_count
FROM customers
JOIN orders ON customers.id = orders.customer_id
WHERE age > 18
GROUP BY name
HAVING orders_count > 5
ORDER BY orders_count DESC
LIMIT 10;

注意:

  • customers 表和 orders连接数据(将每一个顾客(customers 表)与其在 orders 表中的订单匹配起来)。
  • 筛选年龄大于 18 的顾客。
  • 按顾客姓名分组,统计每个顾客的订单数量。
  • 只返回订单数量超过 5 的顾客。
  • 按订单数量降序排列。
  • 只显示前 10 条结果。

二、数据插入语句(INSERT

用于添加新记录

INSERT INTO table_name (column1, column2, ...)
VALUES (value1, value2, ...);

注意:

  • 列出需要插入值的列名对应的值
  • 也可以一次插入多条数据。

三、数据更新语句(UPDATE

用于修改已有数据

UPDATE table_name
SET column1 = value1, column2 = value2, ...
WHERE condition;

注意:

  • WHERE 是关键,指定更新哪些行。若无 WHERE,所有行都会被更新!

四、数据删除语句(DELETE

用于删除表中的数据

DELETE FROM table_name
WHERE condition;

注意:

  • 需使用WHERE 指定删除哪些行,没有 WHERE 会删除所有数据,。

五、表结构操作(DDL)

1. 创建表:

CREATE TABLE table_name (
  id INT PRIMARY KEY AUTO_INCREMENT,
  name VARCHAR(50) NOT NULL,
  age INT,
  created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

注意:

字段名类型约束/说明
idINT主键,自动递增。用于唯一标识每一行记录。
nameVARCHAR(50)最多可存储 50 个字符,不能为空(NOT NULL)。
ageINT存储年龄,整数类型,可以为空(没有 NOT NULL 约束)。
created_atTIMESTAMP时间戳字段,默认值为当前时间CURRENT_TIMESTAMP)。自动记录创建时间。

2. 修改表:

ALTER TABLE table_name
ADD COLUMN email VARCHAR(100);

注意:

  • 修改已有表 table_name新增一个名为 email 的字段,数据类型为 VARCHAR(100)

3. 删除表:

DROP TABLE table_name;

注意:

  • 该代码会删除整个表 table_name

六、事务控制语句

用于保证数据操作的完整性

语句作用说明
START TRANSACTION;显式开启一个事务
BEGIN;等价于 START TRANSACTION开启事务
COMMIT;提交事务,使所有操作永久生效
ROLLBACK;回滚事务,撤销事务内的所有操作
SAVEPOINT 名称;设置一个保存点,可用于局部回滚
ROLLBACK TO SAVEPOINT 名称;回滚到指定保存点
RELEASE SAVEPOINT 名称;删除保存点(不是必须的,但可清理命名空间)
SET AUTOCOMMIT = 0;禁用自动提交(事务需手动提交)

示例——基本事务控制:

START TRANSACTION;

UPDATE accounts SET balance = balance - 100 WHERE id = 1;
UPDATE accounts SET balance = balance + 100 WHERE id = 2;

COMMIT;

注意:

  • 如果两个 UPDATE 都成功,就 COMMIT,资金划转完成。
  • 如果任一失败,执行 ROLLBACK;,保持原始状态。

七、索引相关语句

索引提升查询性能

CREATE INDEX idx_name ON table_name(column_name);
DROP INDEX idx_name ON table_name;

注意:

  • CREATE语句给 users 表的 email 列建立一个索引,查询时 WHERE email = 'xxx' 会更快。
  • DROP语句删除名为 idx_name 的索引。

八、权限控制语句

用于 授予、撤销和查看数据库用户对数据库对象(如数据库、表、列等)的访问权限

语句作用
GRANT授权,赋予用户某些权限
REVOKE撤销,取消用户已有权限
SHOW GRANTS查看某用户的权限
CREATE USER创建新用户
DROP USER删除用户
SET PASSWORD修改用户密码
FLUSH PRIVILEGES刷新权限表(一般不再手动调用)

示例——完整授权流程:

-- 创建用户(创建一个名为 dev 的新用户,密码为 devpass,允许从任意主机(%)连接)
CREATE USER 'dev'@'%' IDENTIFIED BY 'devpass';

-- 授权开发者对 testdb 所有表有全部权限
GRANT ALL PRIVILEGES ON testdb.* TO 'dev'@'%';

-- 查看权限
SHOW GRANTS FOR 'dev'@'%';

-- 撤销 DELETE 权限
REVOKE DELETE ON testdb.* FROM 'dev'@'%';

-- 删除用户
DROP USER 'dev'@'%';
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奕天者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值