MySQL基础(二)----DML学习

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用版 2核4GB 50GB
简介: MySQL基础(二)----DML学习

前言

SELECT确切来说属于DQL(数据查询语言)的指令,但是在对数据库进行操作的时候也会用到查询内容来验证操作结果,
为了便于理解,本篇文章将select也算入DML范围。

SELECT相关高级语法及搭配语句参见DQL文章。

一.DML基本介绍

DML是Database Manipulation Language的缩写,即数据库操作语言。DML是指操作数据库中表格数据的语言,常见的DML操作包括增加(Insert)、查询(Select)、修改(Update)和删除(Delete)表格中的数据。

常见的DML命令

  1. INSERT:向表格中增加一条新记录。
  2. SELECT:查询表格中的数据。
  3. UPDATE:修改表格中已有的记录。
  4. DELETE:从表格中删除某些记录。

举个例子,可以使用INSERT命令向一个学生信息表中插入一条新的记录:

INSERT INTO students (name, grade, score) VALUES ('Tom', '2', '80');

该语句将在students表中插入一条记录,记录包含3个字段:name、grade和score,并将它们设置为’Tom’、‘2’和’80’。这就是DML的常见操作之一。

其他的DML操作包括对表格的行进行修改,可使用UPDATE命令;对表格行进行删除,可使用DELETE命令;对表格进行查询,可使用SELECT命令。DML命令是SQL语言的一部分,是操作关系数据库系统时必备的基本语言。

二.DML常用命令详解

DML 的主要功能是访问数据,语法都是以读取与写入数据库为主,除了INSERT以外,其他指令都可能需搭配WHERE指令来选择数据范围(即过滤内容),不加WHERE指令将访问全部的数据

2.1.INSERT

INSERT 是将数据插入到数据库对象中的指令,可以插入数据的数据库对象:数据表以及可更新查看表

插入数据:

INSERT INTO table_name (column1, column2, column3, ...) VALUES (value1, value2, value3, ...); //对应
添加数据
或者insert into 表 values(值1,值2,值3...); //向表中插入所有列

插入字符串时注意要用双引号或单引号括起来

2.2.DELETE

DELETE 指令为自数据库对象中删除数据的指令。

删除数据:

DELETE FROM table_name WHERE condition;

condition1是指筛选条件,可以使用比较运算符(如=、<、>等)、逻辑运算符(如AND、OR等)和通配符(如%、_等)来进行筛选。另外,还可以使用order by子句对查询结果进行排序,使用group by子句对查询结果进行分组,使用having子句对分组后的结果进行筛选。

例如:

DELETE FROM <表名> [WHERE 子句] [ORDER BY 子句] [LIMIT 子句]

语法说明如下:

<表名>:指定要删除数据的表名。
ORDER BY 子句:可选项。表示删除时,表中各行将按照子句中指定的顺序进行删除。
WHERE 子句:可选项。表示为删除操作限定删除条件,若省略该子句,则代表删除该表中的所有行。
LIMIT 子句:可选项。用于告知服务器在控制命令被返回到客户端前被删除行的最大值。

注意:在不使用 WHERE 条件的时候,将删除所有数据。

2.3.UPDATE

UPDATE 指令是依给定条件,将匹配条件的数据表中的数据更新为新的数值。

更新数据:

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

例如:

使用 UPDATE 语句修改单个表,语法格式为:

UPDATE <表名> SET 字段 1=值 1 [,字段 2=值 2… ] [WHERE 子句 ]

[ORDER BY 子句] [LIMIT 子句] (注意:修改一行数据的多个列值时,SET 子句的每个值用逗号分开。)

语法说明如下:

<表名>:用于指定要更新的表名称。
SET 子句:用于指定表中要修改的列名及其列值。其中,每个指定的列值可以是表达式,也可以是该列对应的默认值。如果指定
的是默认值,可用关键字 DEFAULT 表示列值。
WHERE 子句:可选项。用于限定表中要修改的行。若不指定,则修改表中所有的行。
ORDER BY 子句:可选项。用于限定表中的行被修改的次序。

LIMIT 子句2:可选项。用于限定被修改的行数.

2.4.SELECT

SELECT是SQL数据操纵语言(DML)中用于查询表格内字段数据的指令,可搭配条件限制的子句(如where)或排列顺序的子句(如order)来获取查询结果。

查询数据:

SELECT column1, column2, ... FROM table_name WHERE condition;

SELECT 的语法格式如下:

SELECT
{* | <字段列名>}
[
FROM <表 1>, <表 2>…
[WHERE <表达式>
[GROUP BY <group by definition>
[HAVING <expression> [{<operator> <expression>}…]]
[ORDER BY <order by definition>]
[LIMIT[<offset>,] <row count>]
]

2.4.1.查询表中所有字段

查询所有字段是指查询表中所有字段的数据。MySQL 提供了以下 2 种方式查询表中的所有字段。

使用“*”通配符查询所有字段
列出表的所有字段

1)使用“*”查询表的所有字段

SELECT 可以使用“*”查找表中所有字段的数据,语法格式如下:

SELECT * FROM 表名;

使用“*”查询时,只能按照数据表中字段的顺序进行排列,不能改变字段的排列顺序。

2)列出表的所有字段

SELECT 关键字后面的字段名为需要查找的字段,因此可以将表中所有字段的名称跟在 SELECT 关键字后面。如果忘记了字段名称,可以使用 DESC 命令查看表的结构。

有时,由于表的字段比较多,不一定能记得所有字段的名称,因此该方法很不方便,不建议使用。

2.4.2.查询表中指定的字段

查询表中的某一个字段

语法格式为:

SELECT < 列名 > FROM < 表名 >;

使用 SELECT 声明可以获取多个字段下的数据,只需要在关键字 SELECT 后面指定要查找的字段名称,不同字段名称之间用逗号“,”分隔开,最后一个字段后面不需要加逗号,语法格式如下:

SELECT <字段名1>,<字段名2>,…,<字段名n> FROM <表名>;

三.实例演示:

3.1:条件限制where使用

由于设置表参数时flag列数据长度过短了,就想改一下二行三列数据,精确修改某一内容步骤如下

mysql> select * from test1;
username passwd flag
adm1n 123456 flag{fake_flag!!!}
admin1122 112346 good!give you a excitement 'eg
mysql> UPDATE test1 SET flag = "egg_two!}" WHERE username = "admin1122";
username passwd flag
adm1n 123456 flag{fake_flag!!!}
admin1122 112346 egg_two!}

如果需要修改的数据是前几行修改后要求内一样,可以用LIMIT,如下图(接上表):

mysql> UPDATE test1 SET  flag = "123}" LIMIT 2;
username passwd flag
adm1n 123456 123}
admin1122 112346 123}

  1. 便于识别部分SQL关键词用了小写,使用时候注意换成大写 ↩︎
  2. 默认从第一行开始计算,如果想要指定更改某一行,需要加上限制,如实例演示的3.1。 ↩︎


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
11天前
|
SQL 关系型数据库 MySQL
关于MySQL数据库的学习指南总结
【6月更文挑战第17天】MySQL是流行的关系型DBMS,适合各种应用。学习要点包括安装配置、数据类型、SQL(如SELECT、INSERT)、关系模型、表设计、SQL查询(如WHERE、ORDER BY)、事务处理、用户管理、性能优化和高级技术如存储过程、触发器。了解ACID特性,使用索引和内存优化提升性能,通过备份恢复确保数据安全。不断学习新技术以提升技能。
43 3
|
14天前
|
SQL 关系型数据库 MySQL
MySQL周内训参照2、DDL与DML语句
MySQL周内训参照2、DDL与DML语句
14 1
|
14天前
|
SQL 关系型数据库 MySQL
MySQL数据库子查询练习——DDL与DML语句(包括引入视频)
MySQL数据库子查询练习——DDL与DML语句(包括引入视频)
17 1
|
22天前
|
SQL 关系型数据库 MySQL
MySQL数据库——图形化界面工具(DataGrip),SQL(2)-DML(插入、修改和删除数据)
MySQL数据库——图形化界面工具(DataGrip),SQL(2)-DML(插入、修改和删除数据)
38 1
|
14天前
|
SQL 存储 关系型数据库
MySQL存储过程——Baidu Comate智能代码助手添加20条DML语句——测试索引效果
MySQL存储过程——Baidu Comate智能代码助手添加20条DML语句——测试索引效果
10 0
|
14天前
|
SQL 关系型数据库 MySQL
MySQL单表操作学习DDL_DML_DQL语句
MySQL单表操作学习DDL_DML_DQL语句
14 0
|
14天前
|
SQL 关系型数据库 MySQL
MySQL学习必备SQL_DDL_DML_DQL
MySQL学习必备SQL_DDL_DML_DQL
7 0
|
14天前
|
SQL 安全 关系型数据库
MySQL DML语句insert全表数据添加语句以及注意事项
MySQL DML语句insert全表数据添加语句以及注意事项
27 0
|
1月前
|
SQL 关系型数据库 MySQL
【MySQL进阶之路 | 基础篇】DML之操作数据表
【MySQL进阶之路 | 基础篇】DML之操作数据表
|
1月前
|
SQL 关系型数据库 MySQL
RDS for MySQL的DDL、DML和DQL
这篇文章介绍了MySQL中处理数据的几种主要操作:DDL(Data Definition Language),DML(Data Manipulation Language)和DQL(Data Query Language)。首先讲解了如何使用CREATE DATABASE, ALTER DATABASE和DROP DATABASE语句来创建、修改和删除数据库。
28 1