当前位置: 首页 > news >正文

Mysql基础——DML

数据操作语言(DML,Data Manipulation Language)

DML语句用于对数据库中的数据进行操作(增删改查数据),主要包括:

  • INSERT:向表中插入数据,例如 INSERT INTO table_name (column1, column2) VALUES (value1, value2)
  • UPDATE:更新表中的数据,例如 UPDATE table_name SET column1 = value1 WHERE condition
  • DELETE:删除表中的数据,但不影响表结构,例如 DELETE FROM table_name WHERE condition

DML添加数据:

1. 基本的 INSERT INTO 语句

INSERT INTO 语句用于向表中插入一行或多行数据。

语法:
INSERT INTO 表名 (列名1, 列名2, ...) VALUES (值1, 值2, ...);
  • 表名:需要插入数据的表名。
  • 列名1, 列名2, ...:插入的列名列表。
  • 值1, 值2, ...:每一列对应的值。

注意:
插入数据时,指定的字段顺序需要与值的顺序是一一对应的

字符串和日期型数据应该包含在引号中

插入的数据大小,应该在字段的规定范围内

2. 插入单行数据

示例:

假设有一个 users 表,它有三个字段:idnameemail。我们可以向表中插入一行数据:

INSERT INTO users (name, email) VALUES ('Alice', 'alice@example.com');

这里:

  • id 列是自动递增(AUTO_INCREMENT),所以不需要在插入语句中指定。
  • nameemail 列分别插入 'Alice' 和 'alice@example.com'。

表中的数据:

+----+-------+------------------+
| id | name  | email            |
+----+-------+------------------+
| 1  | Alice | alice@example.com |
+----+-------+------------------+

 3. 插入部分列

如果只想插入部分列,其他未指定的列将会使用默认值(如果有默认值),或者为 NULL

示例:

users 表只插入 name 列:

INSERT INTO users (name) VALUES ('David');

这里没有提供 email 列的值,因此 email 将会被设置为 NULL(假设 email 列允许 NULL)。

4. 给全部字段添加数据

INSERT INTO 表名 VALUES (值1, 值2, ...);

这是向表中所有字段插入数据的写法,你不需要显式列出字段名,只要提供每个字段的值,按照表结构的顺序插入即可。

  • 示例:
INSERT INTO users VALUES (1, 'Bob', 'bob@example.com', CURRENT_TIMESTAMP);

这种形式对应于插入所有字段,适用于你有所有字段的值可以插入的情况。

5. 批量插入多行数据

你可以一次插入多行数据。

语法:
INSERT INTO 表名 (列名1, 列名2, ...) VALUES (值1, 值2, ...), (值1, 值2, ...), ...;
示例:
INSERT INTO users (name, email) 
VALUES 
('Bob', 'bob@example.com'), 
('Charlie', 'charlie@example.com');

表中的数据:

+----+---------+---------------------+
| id | name    | email               |
+----+---------+---------------------+
| 1  | Alice   | alice@example.com    |
| 2  | Bob     | bob@example.com      |
| 3  | Charlie | charlie@example.com  |
+----+---------+---------------------+

总结:

#插入
insert into employee(id, name, gender, age) values(1,'小丽','女',10);
insert into employee(id, name, gender, age) values(2,'大宝','男',20);#单个数据插入
insert into employee values(3,'张三','男',52),(4,'阿梅','女',25);# 多个数据同时插入

通过以下代码来查看表格里面的数据

select * from employee;

控制台输出: 

DML 更新和删除

1. 更新数据:

基本语法

不区分大小写

UPDATA 表名   SET 子段1=值1,子段2=值2 where 条件;修改表中数据
  • SET:指定需要修改的列和新值。
  • where:用于限定更新哪些行。如果省略 where,所有行都会被更新。
update employee set name='不知道' where id=1;

 控制台输出表单:

#更新表中所有数据(不加where)
update  employee SET age='20';

  控制台输出表单:

2. 删除数据(DELETE)

DELETE 语句用于从表中删除一行或多行数据。

基本语法:

DELETE FROM 表名 WHERE 条件;
  • FROM:指定要删除记录的表。
  • WHERE:用于指定删除的条件。如果省略 WHERE,将删除表中的所有记录。
示例1:删除单行数据
DELETE FROM employee WHERE id = 1;

这条语句会删除 id 为1的用户。

2. 删除性别为女的数据
#删除数据
delete from employee where gender='女';

3. 删除所有数据 
#删除所有数据
delete from  employee;

DELETE 用于从表中删除数据,但保留表结构。它可以通过 WHERE 子句删除特定的行,或者删除所有行。

主要特点:
  • 删除数据:只删除表中的数据,不删除表结构。
  • 使用 WHERE 过滤:可以使用 WHERE 子句来删除特定的行。
  • 保留表结构:表的结构和索引、约束等保持不变。
  • 可回滚(在支持事务的存储引擎中,如InnoDB):如果操作在事务内,可以使用 ROLLBACK 回滚删除操作。
  • 不会重置 AUTO_INCREMENTDELETE 不会重置自动递增列的计数器。

TRUNCATE:直接清空表,比 DELETE 效率更高,但不能加 WHERE,并且会重置 AUTO_INCREMENT

 DROP 语句会彻底删除表,不仅删除表中的数据,还会删除表的结构。这意味着表一旦被 DROP,表及其所有的数据、索引、约束、以及触发器等相关信息都会被永久删除,无法恢复,除非有备份。

总结:

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • mysql Field ‘ssl_cipher‘ doesn‘t have a default value的解决
  • OpenFeign:Spring Cloud中的声明式HTTP客户端
  • 2024年汉字小达人区级自由报名备考冲刺:今年官方模拟题练一练
  • SpringSecurity 5
  • 2024.9.18
  • Collections.synchronizedList()
  • 课程首发 | 微软 AI 创新日推荐官招募中
  • General OCR Theory: Towards OCR-2.0 via a Unified End-to-end Model
  • 如何使用ssm实现基于vue.js的购物商场的设计与实现+vue
  • git push命令报错:the remote end hung up unexpectedly
  • 【Transformer深入学习】之一:Sinusoidal位置编码的精妙
  • 升降梯人数识别摄像机
  • 为什么程序员都要了解GPT,学会构建AI大模型?了解GPT大模型,读这本书就够了!
  • Python学习——【2.3】for循环
  • Prometheus监控k8s环境构建
  • Apache的基本使用
  • co.js - 让异步代码同步化
  • EventListener原理
  • HashMap ConcurrentHashMap
  • Intervention/image 图片处理扩展包的安装和使用
  • JDK 6和JDK 7中的substring()方法
  • js
  • VuePress 静态网站生成
  • 大整数乘法-表格法
  • 多线程 start 和 run 方法到底有什么区别?
  • 规范化安全开发 KOA 手脚架
  • 聊聊springcloud的EurekaClientAutoConfiguration
  • 你不可错过的前端面试题(一)
  • 如何学习JavaEE,项目又该如何做?
  • 如何用vue打造一个移动端音乐播放器
  • 树莓派 - 使用须知
  • 思维导图—你不知道的JavaScript中卷
  • 小程序、APP Store 需要的 SSL 证书是个什么东西?
  • 白色的风信子
  • ​RecSys 2022 | 面向人岗匹配的双向选择偏好建模
  • ​学习一下,什么是预包装食品?​
  • #数学建模# 线性规划问题的Matlab求解
  • #职场发展#其他
  • (2)关于RabbitMq 的 Topic Exchange 主题交换机
  • (附源码)ssm教师工作量核算统计系统 毕业设计 162307
  • (附源码)基于ssm的模具配件账单管理系统 毕业设计 081848
  • (更新)A股上市公司华证ESG评级得分稳健性校验ESG得分年均值中位数(2009-2023年.12)
  • (论文阅读23/100)Hierarchical Convolutional Features for Visual Tracking
  • (三)Pytorch快速搭建卷积神经网络模型实现手写数字识别(代码+详细注解)
  • (深入.Net平台的软件系统分层开发).第一章.上机练习.20170424
  • (已解决)什么是vue导航守卫
  • (原创)攻击方式学习之(4) - 拒绝服务(DOS/DDOS/DRDOS)
  • .[hudsonL@cock.li].mkp勒索加密数据库完美恢复---惜分飞
  • .NET C# 使用 iText 生成PDF
  • .Net Core webapi RestFul 统一接口数据返回格式
  • .net core webapi 部署iis_一键部署VS插件:让.NET开发者更幸福
  • .net framwork4.6操作MySQL报错Character set ‘utf8mb3‘ is not supported 解决方法
  • .net 受管制代码
  • .NET 中小心嵌套等待的 Task,它可能会耗尽你线程池的现有资源,出现类似死锁的情况
  • .NET/C# 的字符串暂存池