【MySQL基础随缘更系列】DML语句

2024-06-16 11:44

本文主要是介绍【MySQL基础随缘更系列】DML语句,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

文章目录

    • 一、表记录操作-上
      • 1.1、DML概述
      • 1.2、插入记录
    • 二、表记录操作-下
      • 2.1、更新记录
      • 2.2、删除记录

🌈你好呀!我是 山顶风景独好
🎈欢迎踏入我的博客世界,能与您在此邂逅,真是缘分使然!😊
🌸愿您在此停留的每一刻,都沐浴在轻松愉悦的氛围中。
📖这里不仅有丰富的知识和趣味横生的内容等您来探索,更是一个自由交流的平台,期待您留下独特的思考与见解。🌟
🚀让我们一起踏上这段探索与成长的旅程,携手挖掘更多可能,共同进步!💪✨

数据操纵语言DML(Data Manipulation Language),用户通过它可以实现对数据库的基本操作。就是我们最经常用到的UPDATE、INSERT、DELETE。 主要用来对数据库的数据进行一些操作。

一、表记录操作-上

1.1、DML概述

DML 操作是指对数据库中表记录的操作,主要包括表记录的插入(insert)、更新(update)和删除(delete),是开发人员日常使用最频繁的操作。

1.2、插入记录

格式:
insert into 数据库表名 [字段名列表] values(字段值列表)

说明:

insert into 数据库表名: 指定增加记录的表

[字段名列表]: 表示要给那些字段加入字段值,没有,就为所有字段

values(字段值列表): 表示为对应的字段加入对应的字段值

为所有字段插入值

格式:
insert into 数据库表名(字段名1,字段名2...,字段名n)values(字段值1,字段值2...,字段值n);
或
insert into 数据库表名 values(字段值1,字段值2...,字段值n);

案例:

#指定所有字段插入记录
mysql> insert into student(id,sname,birthday)values(1,"林志颖","1974-10-18");
Query OK, 1 rows affected (0.03 秒)
#不指定字段,默认所有字段插入记录
mysql> insert into student values(2,"郭德纲","1973-01-18");
Query OK, 1 rows affected (0.01 秒)
#查看数据库表中所有记录
mysql> select * from student;
+------+-----------+------------+
| id   | sname     | birthday   |
+------+-----------+------------+
| 1    | 林志颖 | 1974-10-18 |
| 2    | 郭德纲 | 1973-01-18 |
+------+-----------+------------+
2 行于数据集 (0.01 秒)

插入部分字段值

格式:
insert into 数据库表名(字段名1,字段名2...)values(字段值1,字段值2...);
#注意:没有给定字段的值,为null;

案例:

#插入部分字段值
mysql> insert into student(id,sname)values(3,"柳岩");
Query OK, 1 rows affected (0.01 秒)
#查看数据库表中所有记录
mysql> select * from student;
+------+-----------+------------+
| id   | sname     | birthday   |
+------+-----------+------------+
| 1    | 林志颖 | 1974-10-18 |
| 2    | 郭德纲 | 1973-01-18 |
| 3    | 柳岩    | NULL       |
+------+-----------+------------+
3 行于数据集 (0.01 秒)

注意:

只插入部份字段值时,前面必须带字段名字。

mysql> insert into student values(4,"王宝强");
Column count doesn't match value count at row 1#列计数与第1行的值计数不匹配

二、表记录操作-下

2.1、更新记录

格式:
update 数据库表名 set 字段名1=字段值1,字段名2=字段值2...,字段名n=字段值n [where 条件表达式];
#注意:更新的数据可以是0-N条记录

说明:

update 数据库表名: 指定需要更新的数据库表

set 字段名=字段值: 修改指定的数据库表中字段的值

[where 条件表达式]: 修改满足条件的记录的字段值,可省略

不带条件记录更新

格式:
update 数据库表名 set 字段名1=字段值1,字段名2=字段值2...,字段名n=字段值n;  #表示修改表中所有记录

案例:

加入一个性别(sex varchar(2))字段,将sex的值都改为“男”

#在student表中增加字段sex
mysql> alter table student add sex varchar(2);
Query OK, 0 rows affected (0.24 秒)
#查看表结构
mysql> desc student;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id       | int(11)     | YES  |     | NULL    |       |
| sname    | varchar(20) | YES  |     | NULL    |       |
| birthday | date        | YES  |     | NULL    |       |
| sex      | varchar(2)  | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
4 行于数据集 (0.01 秒)
#修改student表中sex字段的值为'男'
mysql> update student set sex='男';
Query OK, 3 rows affected (0.09 秒)
#查看表中所有记录
mysql> select * from student;
+------+-----------+------------+------+
| id   | sname     | birthday   | sex  |
+------+-----------+------------+------+
| 1    | 林志颖 | 1974-10-18 | 男  |
| 2    | 郭德纲 | 1973-01-18 | 男  |
| 3    | 柳岩    | NULL       | 男  |
+------+-----------+------------+------+
3 行于数据集 (0.01 秒)

带条件记录更新

格式:
update 数据库表名 set 字段名1=字段值1,字段名2=字段值2...,字段名n=字段值n [where 条件表达式];   #表示修改表中满足条件的记录

案例:

修改id=3的记录,将sex改为’女’

#修改id为3记录中的sex改为'女'
mysql> update student set sex='女' where id=3;
Query OK, 1 rows affected (0.01 秒)
#查看表中所有记录
mysql> select * from student;
+------+-----------+------------+------+
| id   | sname     | birthday   | sex  |
+------+-----------+------------+------+
| 1    | 林志颖 | 1974-10-18 | 男  |
| 2    | 郭德纲 | 1973-01-18 | 男  |
| 3    | 柳岩    | NULL       | 女  |
+------+-----------+------------+------+
3 行于数据集 (0.01 秒)

修改id=3的记录,将sex改为’女’,birthday改为1980-11-08

#修改id为3记录中的sex改为'女',birthday改为1980-11-08
mysql> update student set sex='女',birthday='1980-11-08' where id=3;
Query OK, 1 rows affected (0.11 秒)
#查看表中所有记录
mysql> select * from student;
+------+-----------+------------+------+
| id   | sname     | birthday   | sex  |
+------+-----------+------------+------+
| 1    | 林志颖 | 1974-10-18 | 男  |
| 2    | 郭德纲 | 1973-01-18 | 男  |
| 3    | 柳岩    | 1980-11-08 | 女  |
+------+-----------+------------+------+
3 行于数据集 (0.01 秒)

2.2、删除记录

格式:
delete from 数据库表名 [where 条件表达式];

说明:

delete from 数据库表名: 指定删除记录的表

[where 条件表达式]: 删除满足条件的记录的字段值,可省略

带条件删除记录

格式:
delete from 数据库表名 [where 条件表达式]; #删除满足条件的记录

案例:

删除id为1的记录

#删除id=1的记录
mysql> delete from student where id=1;
Query OK, 1 rows affected (0.08 秒)
#查看所有记录
mysql> select * from student;
+------+-----------+------------+------+
| id   | sname     | birthday   | sex  |
+------+-----------+------------+------+
| 2    | 郭德纲 | 1973-01-18 | 男  |
| 3    | 柳岩    | 1980-11-08 | 女  |
+------+-----------+------------+------+
2 行于数据集 (0.02 秒)

不带条件删除记录

格式:
delete from 数据库表名;    #删除表中所有的记录
或
truncate table 数据库表名;   #删除表中所有的记录

案例:

删除表中所有记录

#删除所有记录
mysql> delete from student;
Query OK, 2 rows affected (0.08 秒)
#查看所有记录
mysql> select * from student;
空的数据集 (0.01 秒)
#删除所有记录
mysql> truncate table student;
Query OK, 0 rows affected (0.08 秒)
#查看所有记录
mysql> select * from student;
空的数据集 (0.01 秒)

注意:

truncate删除的是表的结构,再创建一张表;delete删除的是表的记录;


✨ 这就是今天要分享给大家的全部内容了,我们下期再见!😊
🏠 我在CSDN等你哦!我的主页😍

这篇关于【MySQL基础随缘更系列】DML语句的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1066374

相关文章

SQL中redo log 刷⼊磁盘的常见方法

《SQL中redolog刷⼊磁盘的常见方法》本文主要介绍了SQL中redolog刷⼊磁盘的常见方法,将redolog刷入磁盘的方法确保了数据的持久性和一致性,下面就来具体介绍一下,感兴趣的可以了解... 目录Redo Log 刷入磁盘的方法Redo Log 刷入磁盘的过程代码示例(伪代码)在数据库系统中,r

mysql中的group by高级用法

《mysql中的groupby高级用法》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,下面给大家介绍mysql中的groupby用法... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

Mysql用户授权(GRANT)语法及示例解读

《Mysql用户授权(GRANT)语法及示例解读》:本文主要介绍Mysql用户授权(GRANT)语法及示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql用户授权(GRANT)语法授予用户权限语法GRANT语句中的<权限类型>的使用WITH GRANT

Mysql如何解决死锁问题

《Mysql如何解决死锁问题》:本文主要介绍Mysql如何解决死锁问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录【一】mysql中锁分类和加锁情况【1】按锁的粒度分类全局锁表级锁行级锁【2】按锁的模式分类【二】加锁方式的影响因素【三】Mysql的死锁情况【1

SQL BETWEEN 的常见用法小结

《SQLBETWEEN的常见用法小结》BETWEEN操作符是SQL中非常有用的工具,它允许你快速选取某个范围内的值,本文给大家介绍SQLBETWEEN的常见用法,感兴趣的朋友一起看看吧... 在SQL中,BETWEEN是一个操作符,用于选取介于两个值之间的数据。它包含这两个边界值。BETWEEN操作符常用

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例