MySQL DML(数据操作语言)全面指南

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL DML(数据操作语言)全面指南

MySQL DML(数据操作语言)全面指南

MySQL的数据操作语言(DML,Data Manipulation Language)是SQL中用于操作数据库中数据的核心部分。它主要包括插入(INSERT)、更新(UPDATE)、删除(DELETE)以及查询(SELECT)数据的操作。本文将详细讲解这些基本DML命令的使用方法,并通过实例代码让你快速掌握它们的精髓。

一、插入数据(INSERT)

INSERT语句用于向表中插入新的数据记录。

基础插入

INSERT INTO users (username, email)
VALUES ('John Doe', 'john.doe@example.com');

上述命令在users表中插入了一条新记录,指定了usernameemail字段的值。

批量插入

如果你想一次插入多条记录,可以这样做:

INSERT INTO users (username, email)
VALUES ('Jane Smith', 'jane.smith@example.com'),
       ('Jim Brown', 'jim.brown@example.com');

二、更新数据(UPDATE)

UPDATE语句用于修改表中已存在的记录。

UPDATE users
SET email = 'new.email@example.com'
WHERE username = 'John Doe';

此命令将users表中username为'John Doe'的用户的email字段更新为'new.email@example.com'。

三、删除数据(DELETE)

DELETE语句用于从表中删除记录。

DELETE FROM users
WHERE email = 'old.email@example.com';

这将删除users表中所有email为'old.email@example.com'的记录。

四、查询数据(SELECT)

SELECT是最常用的DML命令,用于从表中检索数据。

基础查询

SELECT * FROM users;

此命令返回users表中的所有记录和字段。

条件查询

SELECT username, email FROM users
WHERE age > 18;

仅显示年龄大于18岁的用户的usernameemail

排序与限制

SELECT * FROM users
ORDER BY age DESC
LIMIT 10;

按年龄降序排列,并只显示前10条记录。

聚合函数

SELECT COUNT(*) FROM users;

计算users表中的记录总数。

分组与HAVING

SELECT gender, COUNT(*) as total_users
FROM users
GROUP BY gender
HAVING total_users > 50;

按性别分组,显示每个性别用户数超过50人的统计。

五、联接查询(JOIN)

联接查询用于从两个或更多表中检索相关数据。

SELECT users.username, orders.order_id
FROM users
INNER JOIN orders ON users.id = orders.user_id;

此查询通过用户ID联接usersorders表,显示每个用户的最近订单信息。

六、子查询

子查询是嵌套在另一个查询中的查询,用于作为外部查询的条件或数据来源。

SELECT * FROM users
WHERE id IN (SELECT user_id FROM orders WHERE status = 'completed');

这将找出所有有已完成订单的用户。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6天前
|
存储 SQL 关系型数据库
MySQL底层概述—4.InnoDB数据文件
本文介绍了InnoDB表空间文件结构及其组成部分,包括表空间、段、区、页和行。表空间是最高逻辑层,包含多个段;段由若干个区组成,每个区包含64个连续的页,页用于存储多条行记录。文章还详细解析了Page结构,分为通用部分(文件头与文件尾)、数据记录部分和页目录部分。此外,文中探讨了行记录格式,包括四种行格式(Redundant、Compact、Dynamic和Compressed),重点介绍了Compact行记录格式及其溢出机制。最后,文章解释了不同行格式的特点及应用场景,帮助理解InnoDB存储引擎的工作原理。
MySQL底层概述—4.InnoDB数据文件
|
14天前
|
Java 关系型数据库 MySQL
SpringBoot 通过集成 Flink CDC 来实时追踪 MySql 数据变动
通过详细的步骤和示例代码,您可以在 SpringBoot 项目中成功集成 Flink CDC,并实时追踪 MySQL 数据库的变动。
115 43
|
2月前
|
存储 关系型数据库 MySQL
mysql怎么查询longblob类型数据的大小
通过本文的介绍,希望您能深入理解如何查询MySQL中 `LONG BLOB`类型数据的大小,并结合优化技术提升查询性能,以满足实际业务需求。
177 6
|
2月前
|
SQL 关系型数据库 MySQL
mysql分页读取数据重复问题
在服务端开发中,与MySQL数据库进行数据交互时,常因数据量大、网络延迟等因素需分页读取数据。文章介绍了使用`limit`和`offset`参数实现分页的方法,并针对分页过程中可能出现的数据重复问题进行了详细分析,提出了利用时间戳或确保排序规则绝对性等解决方案。
119 1
|
3月前
|
关系型数据库 MySQL 数据库
GBase 数据库如何像MYSQL一样存放多行数据
GBase 数据库如何像MYSQL一样存放多行数据
|
3天前
|
关系型数据库 MySQL 网络安全
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
42 25
|
12天前
|
关系型数据库 MySQL 数据库
Docker Compose V2 安装常用数据库MySQL+Mongo
以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。
90 42
|
25天前
|
关系型数据库 MySQL 数据库连接
数据库连接工具连接mysql提示:“Host ‘172.23.0.1‘ is not allowed to connect to this MySQL server“
docker-compose部署mysql8服务后,连接时提示不允许连接问题解决
|
30天前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
253 0
|
2月前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
73 3