滚雪球学MySQL[2.2讲]:基本数据操作详解:插入、查询、更新与删除
全文目录:
- 前言
- 2.2 基本数据操作
- 1. 插入数据(INSERT)
- 基本语法
- 示例1:向所有列插入数据
- 示例2:插入部分列的数据
- 2. 查询数据(SELECT)
- 基本语法
- 示例1:查询所有数据
- 示例2:查询特定列的数据
- 示例3:使用条件过滤查询
- 3. 更新数据(UPDATE)
- 基本语法
- 示例1:更新特定行的数据
- 示例2:更新多列数据
- 小心误区
- 4. 删除数据(DELETE)
- 基本语法
- 示例1:删除特定行的数据
- 示例2:删除符合条件的多行数据
- 示例3:删除所有数据
- 拓展:批量操作与事务管理
- 示例:事务的使用
- 结语与下期预告
前言
在上一期的学习中,我们深入探讨了MySQL数据库与表的基本操作(2.1),从创建数据库、创建表到修改表结构等基础内容。通过这些操作,我们为存储和管理数据打下了基础。掌握了数据库和表的操作后,下一步就是如何在这些表中进行数据的增删改查,这也是数据库管理中最为核心的部分。
本期内容将重点介绍MySQL中的基本数据操作,包括插入数据(INSERT)、查询数据(SELECT)、更新数据(UPDATE)和删除数据(DELETE)。这四种操作在日常开发中非常常见,通过本篇内容,你将全面掌握如何操作数据库中的数据,并通过具体的案例帮助你更好地理解与实践。
在本期内容的学习结束后,下一期将进一步探讨MySQL中的数据过滤与排序(2.3),帮助你更高效地从数据库中提取所需信息。
2.2 基本数据操作
在数据库操作中,数据的增删改查是最基础的功能,通常使用SQL语句来进行这些操作。MySQL提供了多种灵活的方式来操作数据,我们将逐一介绍这些基本操作,并通过示例进行深入讲解。
1. 插入数据(INSERT)
INSERT语句用于向数据库表中插入新的数据行。它有两种常见的使用方式:一种是向所有列插入数据,另一种是向指定列插入数据。
基本语法
INSERT INTO 表名 (列1, 列2, ...) VALUES (值1, 值2, ...);
示例1:向所有列插入数据
假设我们有一个名为students
的表,其结构如下:
CREATE TABLE students (
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(50),
age INT,
major VARCHAR(50)
);
向students
表中插入一行数据:
INSERT INTO students (name, age, major) VALUES ('Alice', 20, 'Computer Science');
在这个例子中,我们指定了name
、age
和major
三列的值,数据库会自动为id
列生成唯一的值(因为id
是自增的)。
示例2:插入部分列的数据
如果你不需要插入所有列的数据,可以只为部分列提供值,其他未指定的列会被设置为默认值(如果存在默认值)。
INSERT INTO students (name, major) VALUES ('Bob', 'Mathematics');
在此示例中,age
列将使用默认值或为空值(NULL),而id
列仍然会自动递增。
2. 查询数据(SELECT)
SELECT语句用于从数据库表中查询数据,是最常用的SQL语句之一。它可以灵活地根据条件从数据库中提取数据,并且支持排序、分组、聚合等功能。
基本语法
SELECT 列1, 列2, ... FROM 表名 WHERE 条件;
示例1:查询所有数据
查询students
表中的所有数据:
SELECT * FROM students;
*
表示选择所有列,执行结果会显示表中的所有记录。
示例2:查询特定列的数据
如果只想查询特定列,可以指定列名:
SELECT name, major FROM students;
这个查询将返回students
表中的name
和major
列,其他列则不会显示。
示例3:使用条件过滤查询
你还可以在查询中使用WHERE
子句来过滤数据。例如,查询所有age
大于20的学生:
SELECT * FROM students WHERE age > 20;
这个查询只会返回那些age
大于20的记录。
3. 更新数据(UPDATE)
UPDATE语句用于更新表中已有的数据。你可以指定更新哪些行,并为这些行设置新的值。使用UPDATE
时必须小心,避免在没有WHERE
条件的情况下更新所有记录。
基本语法
UPDATE 表名 SET 列1 = 值1, 列2 = 值2, ... WHERE 条件;
示例1:更新特定行的数据
假设我们想要更新students
表中id
为1的学生的年龄:
UPDATE students SET age = 21 WHERE id = 1;
这个语句将id
为1的那一行的age
列值更新为21。
示例2:更新多列数据
你也可以同时更新多列:
UPDATE students SET age = 22, major = 'Physics' WHERE id = 2;
该语句会更新id
为2的记录,将age
设为22,将major
设为Physics
。
小心误区
注意:如果忘记加WHERE
子句,所有行的数据都会被更新。例如,以下语句会更新表中的所有记录,将每个学生的age
都设为25:
UPDATE students SET age = 25;
因此,在执行UPDATE
操作时,一定要慎重使用WHERE
条件。
4. 删除数据(DELETE)
DELETE语句用于从表中删除指定的行数据。与UPDATE
类似,删除操作也应该慎用,特别是在没有WHERE
条件时,可能会删除表中的所有数据。
基本语法
DELETE FROM 表名 WHERE 条件;
示例1:删除特定行的数据
假设我们要删除id
为3的学生记录:
DELETE FROM students WHERE id = 3;
此语句会删除students
表中id
为3的那一行。
示例2:删除符合条件的多行数据
如果需要删除多条符合条件的数据,比如删除所有age
小于18的学生:
DELETE FROM students WHERE age < 18;
此操作会删除students
表中所有age
小于18的记录。
示例3:删除所有数据
慎重使用! 如果你要清空表中的所有数据,可以不加WHERE
条件:
DELETE FROM students;
此语句将删除表中所有数据,但表的结构不会受影响。如果你想彻底清空表并重置自增主键,可以使用TRUNCATE
:
TRUNCATE TABLE students;
TRUNCATE
比DELETE
速度更快,但会重置自增列计数。
拓展:批量操作与事务管理
在实际应用中,很多情况下你需要批量操作数据或确保一组操作要么全部成功,要么全部失败。MySQL通过事务(transaction)来保证这种操作的原子性。
示例:事务的使用
假设你在处理多个操作时,希望这些操作要么全部成功,要么全部撤销。例如,转账操作中涉及从一个账户扣款并向另一个账户存款:
START TRANSACTION;
UPDATE accounts SET balance = balance - 100 WHERE id = 1;
UPDATE accounts SET balance = balance + 100 WHERE id = 2;
COMMIT;
如果任何一步失败,都可以通过ROLLBACK
撤销:
ROLLBACK;
事务确保了数据的一致性,是数据库操作中非常重要的功能。
结语与下期预告
通过本期的学习,你已经掌握了MySQL中最基本的四种数据操作:插入(INSERT)、查询(SELECT)、更新(UPDATE)和删除(DELETE)。这些操作是数据库日常操作中最常用的,也是掌握数据库管理的核心技能。
在下期内容中,我们将深入探讨MySQL中的数据过滤与排序(2.3),帮助你更精准地获取和管理数据。届时你将学习如何通过WHERE
子句进行复杂条件过滤、如何使用ORDER BY
对结果集排序以及如何通过LIMIT
和OFFSET
分页查询结果。敬请期待!