SQL第16课——更新和删除数据

介绍如何利用updatedelete语句进一步操作表数据。

16.1 更新数据

使用update语句。两种使用方式:

  1. 更新表中的特定行;

  2. 更新表中的所有行。

!!!(使用update时不要省略where子句,因为容易更新表中的所有行)

基本update语句由三部分组成 = 要更新的表 + 列名和它们的新值 + 确定要更新哪些行的过滤条件

**例:**客户1000000005现在有了电子邮件地址,因此需要更新记录

更新单个列:

这里是更新customers表中cust_id为1000000005的email.

没有where子句的话,DBMS将会用这个电子邮件地址更新customers表中的所有行。

更新多个列:

**!!!**在update语句中使用子查询,使得能用select语句检索出的数据更新列数据。

有的SQL实现支持在update语句中使用from子句,用一个表的数据更新另一个表的行。

删除某个列的值,可设置它为null(表定义允许null值):

null去除cust_email列中的值,与保存空字符串不同(' ',是一个值),null表示没有值。

16.2 删除数据

delete删除(去掉)数据,有两种方式:

  1. 删除特定的行;

2.删除所有行。

同样不要省略where子句,不然容易删除所有行。

**例:**从customers表中删除一行:

delete from 指定删除的表名

!!!友好的外键

12课中的联结,简单联结两个表需要两个表中的公用字段,

使用外键确保引用完整性的好处:DBMS通常可以防止删除某个关系需要用到的行。如从Products表中删除一个产品,但这个产品用在orderitems的已有订单中,那么delete语句将抛出错误并中止。

delete不需要列名或通配符,delete删除整行而不是删除列,删除指定的列,使用update语句。

delete删除行,不删除表本身

要删除所有行,用truncate table语句更快。

16.3 更新和删除的指导原则

|------------------------------------------------------|
| 1. 如果不是更新或删除每一行,那么一定要使用where子句 |
| 2. 保证每个表都有主键,尽可能像where子句那样使用它(可以指定各主键,多个值或值的范围) |
| 3. 在使用where子句前,应该先用select进行测试,保证过滤的是正确的记录 |
| 4. 使用强制实施引用完整性的数据库,这样DBMS将不允许删除其数据与其他表相关联的行 |
| 5. 有得DBMS允许数据库管理员施加约束,防止执行不带where子句得update或delete语句。 |
| 6. 如果SQL没有撤销(undo)按钮,小心使用,不然容易更新或删除错误数据。 |
[update和delete遵循的重要原则]

相关推荐
Elastic 中国社区官方博客44 分钟前
Elasticsearch:使用 Agent Builder 的 A2A 实现 - 开发者的圣诞颂歌
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
2301_816660211 小时前
PHP怎么处理Eloquent Attribute Inference属性推断_Laravel从数据自动推导类型【操作】
jvm·数据库·python
qq_372154232 小时前
Go 中自定义类型与基础类型的显式转换规则详解
jvm·数据库·python
_下雨天.2 小时前
NoSQL之Redis配置与优化
数据库·redis·nosql
LiAo_1996_Y3 小时前
CSS如何实现文字渐变效果_通过background-clip实现艺术字
jvm·数据库·python
2401_887724503 小时前
CSS如何让表单在手机端友好展示_利用Flexbox实现堆叠排版
jvm·数据库·python
数据库小组3 小时前
MySQL 删库后怎么恢复?binlog2sql 之外,NineData 还能做什么
数据库·sql·mysql·安全·数据·ninedata·删库
zhangchaoxies3 小时前
Layui轮播图(carousel)怎么设置自动播放间隔
jvm·数据库·python
切糕师学AI3 小时前
HBase:一文搞懂分布式宽列数据库(原理 + 架构 + 实战)
数据库·分布式·nosql·hbase·分布式宽列数据库·wide column db
competes3 小时前
慈善基金投资底层逻辑应用 顶层代码低代码配置平台开发结构方式数据存储模块
java·开发语言·数据库·windows·sql