基础-SQL-DML

一、MySQL基础

1. DML

在数据库管理中,DML(Data Manipulation Language) 是最频繁使用的 SQL 子集,它直接决定了数据的增删改查效率与准确性。本文将通过实际场景和代码示例,系统解析 DML 的核心操作(INSERTUPDATEDELETESELECT),并探讨其在业务场景中的应用逻辑。

1.2 添加数据

核心功能:向表中添加新记录,需严格匹配字段类型与约束。

1. 指定字段插入

适用于表结构复杂或仅需更新部分字段的场景。

注意 :字段顺序必须与值列表一致,字符串和日期需用引号包裹(如 '2025-12-26')。

2. 全字段插入

适用于表结构简单或字段顺序与值顺序一致的情况。

风险提示:若表结构变更(如新增字段),此语法可能导致插入失败。

3. 子查询插入

通过查询其他表的数据填充目标表。

sql 复制代码
# 注意:
#   1、字段一定要一一对应
#   2、插入的数据一定要在数据类型的范围内
#   3、字符串和日期一定要在''中
# 1、插入指定字段
insert into employee(id, workno, name, age, idcard, entrydate,gender) values (1,'1','ItCast',10,'123456789123456789','2025-12-26','男');
insert into employee(id, workno, name, age, idcard, entrydate,gender) values (2,'2','lkbHua',21,'123456789123456189','2005-5-31','男');
insert into employee(id, workno, name, age, idcard, entrydate,gender) values (3,'1','ZengQ',18,'123456789123456289','2005-12-12','女');

# 查询表的方法有两种
# case1: 直接双击employee
# case2: 使用sql语句,select * from employee
#        然后点击执行

# 2、插入全部字段
insert into employee values (4,'3','LaoP',20,'123456789123456389','2005-6-6','女');

# 3、批量插入
insert into employee values (4,'3','LaoP',20,'123456789123456389','2005-6-6','女'),(7,'3','LaoP',20,'123456789123456389','2005-6-6','女');

1.3 更新和删除

核心功能 :更新表中已有记录,需通过 WHERE 条件 精准定位目标行。

1. 单表更新

关键原则

  • 避免省略 WHERE 子句:否则会更新全表数据!
  • 事务控制:在关键业务(如订单状态更新)中,建议用事务包裹操作。
2. 多表关联更新

通过 JOIN 实现跨表更新(部分数据库支持,如 MySQL 8.0+)。

核心功能:删除表中记录,需严格验证条件逻辑。

1. 单表删除

注意事项

  • TRUNCATE vs DELETETRUNCATE 直接释放存储空间,无法通过事务回滚;DELETE 可配合 WHERE 条件逐行删除。
  • 外键约束:删除主表数据前需确保从表无关联记录(或设置级联删除)。
2. 多表关联删除
sql 复制代码
-- 删除无订单记录的客户(关联订单表)  
DELETE FROM customers c  
LEFT JOIN orders o ON c.id = o.customer_id  
WHERE o.order_id IS NULL;
相关推荐
曹牧2 分钟前
Spring Boot:如何在Java Controller中处理POST请求?
java·开发语言
浅念-5 分钟前
C++入门(2)
开发语言·c++·经验分享·笔记·学习
WeiXiao_Hyy6 分钟前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
玄同7657 分钟前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
吾日三省吾码8 分钟前
别只会“加索引”了!这 3 个 PostgreSQL 反常识优化,能把性能和成本一起打下来
数据库·postgresql
chian-ocean10 分钟前
百万级图文检索实战:`ops-transformer` + 向量数据库构建语义搜索引擎
数据库·搜索引擎·transformer
User_芊芊君子12 分钟前
CANN010:PyASC Python编程接口—简化AI算子开发的Python框架
开发语言·人工智能·python
Max_uuc22 分钟前
【C++ 硬核】打破嵌入式 STL 禁忌:利用 std::pmr 在“栈”上运行 std::vector
开发语言·jvm·c++
故事不长丨23 分钟前
C#线程同步:lock、Monitor、Mutex原理+用法+实战全解析
开发语言·算法·c#
牵牛老人26 分钟前
【Qt 开发后台服务避坑指南:从库存管理系统开发出现的问题来看后台开发常见问题与解决方案】
开发语言·qt·系统架构