【MySQL新手入门系列三】:MySQL的新增、删除与修改操作

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 在 MySQL 中,对数据的操作分为典型的“增删改查”四个操作。前面我们已经大致讲了一下mysql的安装等介绍,本篇博客将详解 MySQL 中的“新增、删除与修改”操作。

在 MySQL 中,对数据的操作分为典型的“增删改查”四个操作。前面我们已经大致讲了一下mysql的安装等介绍,本篇博客将详解 MySQL 中的“新增、删除与修改”操作。

一、SQL语句规则

每一门开发语音都有自己的语法规则,在写 SQL 语句时,要遵守下面几个书写规则:

1.1 SQL 语句要以分号;结尾

在关系型数据库中,SQL 语句是逐条执行的,一条 SQL 语句代表着数据库的一个操作,而一个分号表示这句话结束。
除了某些数据库不要求分号作为语句结束符号除外。

1.2 SQL 语句中单词需要用英文空格来分隔

没有分隔的语句会发生错误,无法正常执行。

1.3 SQL 语句不区分大小写

但实际开发中,关键字通常使用大写,数据库名、表名和列名等小写,
在实际编写SQL语句时,胡乱的大小写混用会使代码可读性变差,因此应使用统一的大小写风格。

1.4 SQL 语句注释

SQL 语句中的注释由连字符 -- 或 #、及包含在 // 之间的注释块所组成。注释可以提高代码的可读性和易维护性。

1.5 SQL 语句中的关键字

SQL 语句中的关键字表示某种操作类型,如 SELECT、INSERT、UPDATE、DELETE,这些关键字只用于执行该操作类型。

二、如何添加新数据记录

添加新数据记录语法:

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

其中,INSERT INTO 语句是向 MySQL 数据库中插入新数据记录的关键语句,table_name 表示待插入数据的数据表名称,column1、column2、column3 等为表中各列的名称,value1、value2、value3 等为待插入的数据值。

例如,我们要向名为“students”的表中插入一条新纪录,该纪录含“ID”、“Name”和“Age”三个字段,相应的 INSERT INTO 语句如下:

INSERT INTO students (ID, Name, Age) VALUES (1, ‘张三’, 20);

这个 SQL 语句的意思是,在“students”表中插入一条新的记录,该记录的 ID 为 1,Name 为 “张三”,Age 为 20。

再比如,插入多条数据:

插入一些数据到 "books" 数据表
INSERT INTO books(title, author, price) VALUES('C++ Programming', 'John Smith', 29.99);
INSERT INTO books(title, author, price) VALUES('Java Programming', 'Jane Doe', 39.99);
INSERT INTO books(title, author, price) VALUES('Python Programming', 'Bob Johnson', 24.99);

此外, INSERT INTO 语句还可以通过子查询来插入一组数据,例如:


INSERT INTO students (ID, Name, Age) SELECT ID, Name, Age FROM other_students WHERE Age > 20;

以上 SQL 语句的含义是:从名为“other_students”的表中选择年龄大于 20 的学生信息,再将其插入到“students”表中。

三、如何删除现有的数据记录

语法格式为:

 DELETE FROM table_name WHERE condition;。

其中,DELETE FROM 表示从指定表中删除数据记录,table_name 表示指定的表名,WHERE 语句可选,其表示指定的条件。

例如,如果我们要从名为“students”的表中删除年龄为 20 的记录,那么相应的 SQL 语句是这样的:

DELETE FROM students WHERE Age = 20;

如果不指定 WHERE 语句,表示将表中的所有记录删除:

DELETE FROM students;

特别注意:执行 DELETE 语句时,要确保自己所删除的数据是真正需要删除的,因为 MySQL 的 DELETE 语句没有回滚功能(即删除之后就不可逆转了)。

四、如何修改现有的数据记录

语法格式为:

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

其中,UPDATE 表示更新指定表中的数据记录,table_name 表示指定的表名,SET 语句用于设定所要更新的字段及其对应的新值,WHERE 语句用于指定更新的条件。

例如,如果我们要更新名为“students”的表中“ID”为 1 的学生的姓名和年龄,那么相应的 SQL 语句是这样的:


UPDATE students SET Name = ‘李四’, Age = 22 WHERE ID = 1;

这个 SQL 语句的意思是:将“students”表中“ID”为 1 的那行记录的“Name”更新为“李四”,“Age”更新为 22。

五、如何查询数据记录

查询数据记录是 MySQL 中最基础、最常见的操作之一。
下面是查询数据记录的示例 SQL 语句:

SELECT * FROM table_name;

其中,"table_name" 是要查询的表名,"*" 表示查询表中的所有字段。这个语句查询了表中的所有数据记录。

比如查询books表中的所有数据:

SELECT * FROM books;

通常,我们会根据一些条件来筛选数据。这时候,可以使用 WHERE 子句来指定查询条件。例如:

SELECT * FROM table_name WHERE column_name = 'value';

上面的语句将查询表中满足 "column_name" 字段等于 "value" 的记录。

除了 WHERE 子句,还可以使用 ORDER BY 子句来按照某个字段进行排序,使用 LIMIT 子句来限制查询的数量。例如:

SELECT * FROM table_name WHERE column_name = 'value' ORDER BY column_name2 DESC LIMIT 10;

上面的语句将查询表中 "column_name" 字段等于 "value" 的记录,并按照 "column_name2" 字段进行降序排序,只返回前 10 条记录。

六、学习 SQL语言的约束、自动增长、外键等高效实用的特性

在 MySQL 数据库的使用中,SQL语句中还有很多其他的语法,它们包括 约束(constraints)、自动增长(auto-increment)、触发器(triggers)、存储过程(stored procedures)、视图(views)、索引(indexes)、游标(cursors)等,
MySQL 提供了一些强大的特性来保证数据的完整性与一致性,以下是其中一些高效实用的特性:

  1. 约束(Constraint)

MySQL 中的约束主要包括主键约束、唯一约束、非空约束和外键约束等。通过定义约束,我们可以有效地保证数据的完整性和一致性。

例如,我们可以使用以下语句来定义一个名为 "users" 的表,并在 "id" 字段上添加主键约束:

CREATE TABLE users (
  id INT(11) NOT NULL AUTO_INCREMENT,
  name VARCHAR(255) NOT NULL,
  email VARCHAR(255) NOT NULL,
  PRIMARY KEY (id)
);

上例中,"id" 字段被设置为主键约束后,就不能重复插入相同的值,从而保证了数据的唯一性。

  1. 自动增长

MySQL 中提供了 AUTO_INCREMENT 属性,可以使得某个字段在插入新数据时自动增加,方便了数据的处理。

例如,在上面定义的 "users" 表中,我们可以设置 "id" 字段为自动增长:

CREATE TABLE users (
  id INT(11) NOT NULL AUTO_INCREMENT,
  name VARCHAR(255) NOT NULL,
  email VARCHAR(255) NOT NULL,
  PRIMARY KEY (id)
);

这样,在插入新数据时,不需要手动为 "id" 字段指定值,数据库会自动为其生成递增的唯一值。

  1. 外键(Foreign Key)

MySQL 中的外键是一种非常有用的约束特性,在多张表之间建立关联,保证其完整性和一致性。通过定义外键关系,可以方便地实现表之间的级联操作等自动化性能,将插入、删除、更新等操作自动化实现。

例如,我们可以在定义 "users" 表的同时,创建一个名为 "orders" 的订单表,并在其中定义一个外键指向 "users" 表中的 "id" 字段:

CREATE TABLE orders (
  id INT(11) NOT NULL AUTO_INCREMENT,
  user_id INT(11),
  product_name VARCHAR(255) NOT NULL,
  PRIMARY KEY (id),
  FOREIGN KEY (user_id) REFERENCES users(id)
);

在上面的例子中,"orders" 表中的 "user_id" 字段与 "users" 表中的 "id" 字段建立了外键关系。这样,当向 "orders" 表插入数据时,只能插入在 "users" 表中已经存在的 "id" 值,保证了数据之间的相互关联。

以上就是简单的增删改查操作,作为入门级别的教程,还是非常简单的。

请注意,示例仅涵盖了MySQL的一小部分功能,请参阅更多的MySQL文档和教程以了解更多信息和实际应用。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
5月前
|
安全 关系型数据库 MySQL
PHP与MySQL交互:从入门到实践
【9月更文挑战第20天】在数字时代的浪潮中,掌握PHP与MySQL的互动成为了开发动态网站和应用程序的关键。本文将通过简明的语言和实例,引导你理解PHP如何与MySQL数据库进行对话,开启你的编程之旅。我们将从连接数据库开始,逐步深入到执行查询、处理结果,以及应对常见的挑战。无论你是初学者还是希望提升技能的开发者,这篇文章都将为你提供实用的知识和技巧。让我们一起探索PHP与MySQL交互的世界,解锁数据的力量!
|
1月前
|
SQL 关系型数据库 MySQL
网安入门之MySQL后端基础
《网安入门之MySQL后端基础》简介: 本文介绍了数据库及MySQL的基础知识,涵盖数据库的概念、结构与操作。数据库是组织化存储数据的集合,通过表、列、行等结构实现高效管理。MySQL作为开源的关系型数据库管理系统,广泛应用于Web开发。文中详细讲解了MySQL的基本操作,如增(INSERT)、删(DELETE)、改(UPDATE)、查(SELECT)等语句的使用方法,并介绍了数据库事务的ACID特性。此外,还探讨了SQL注入攻击的风险及防范措施,强调了预处理语句的重要性。最后,简述了PHP中mysqli扩展的使用方法,包括连接数据库、执行查询和关闭连接等步骤。
|
5月前
|
关系型数据库 MySQL 数据库
MySQL基本操作入门指南
MySQL基本操作入门指南
191 0
|
7月前
|
SQL 运维 关系型数据库
MySQL 中 GRANT 操作会引起复制中断吗?
GRANT 操作并不是一个原子性操作,不管执行成功与否,都会触发一个隐式重载授权表的行为。 在生产环境中需要规范用户创建及授权的操作,不推荐使用 DML 语句去直接变更 mysql.user 表,可能会引发其他的问题,若使用了 DML 语句进行变更, 需要手工执行 flush privileges。
98 4
|
7月前
|
JavaScript 关系型数据库 MySQL
创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作
创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作
92 0
|
5月前
|
SQL 关系型数据库 MySQL
MySQL入门到精通
MySQL入门到精通
|
7月前
|
存储 关系型数据库 文件存储
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
62 2
|
7月前
|
SQL 关系型数据库 MySQL
实时计算 Flink版操作报错合集之从mysql读数据写到hive报错,是什么原因
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
7月前
|
消息中间件 关系型数据库 MySQL
实时计算 Flink版操作报错合集之运行mysql to doris pipeline时报错,该如何排查
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
7月前
|
消息中间件 关系型数据库 MySQL
实时计算 Flink版操作报错合集之整库同步mysql到starRock提交任务异常,该如何处理
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。