笨办法学 Python · 续 练习 42:SQL 删除
2017-08-15 11:13
197 查看
练习 42:SQL 删除
原文:EExercise 42: Deleting with SQL译者:飞龙
协议:CC BY-NC-SA 4.0
自豪地采用谷歌翻译
这是最简单的练习,但我希望你键入代码之前思考一秒钟。如果你将
SELECT写成
"SELECT * FROM",将
INSERT写成
"INSERT INTO",那么你会怎么编写
DELETE格式?你可以看下面,但是试着猜测它会是什么,然后看一看。
/* make sure there's dead pets */ SELECT name, age FROM pet WHERE dead = 1; /* aww poor robot */ DELETE FROM pet WHERE dead = 1; /* make sure the robot is gone */ SELECT * FROM pet; /* let's resurrect the robot */ INSERT INTO pet VALUES (1, "Gigantor", "Robot", 1, 0); /* the robot LIVES! */ SELECT * FROM pet;
我只是简单地通过删除它,然后使用
dead=0将记录放回去,来为机器人实现非常复杂的更新。在以后的练习中,我将向你展示,如何使用
UPDATE来实现它,所以不要以为这是更新的真正方法。
你已经熟悉了这个脚本中的大多数行,除了第五行。这里你拥有
DELETE,它与其他命令格式几乎相同。你提供了
DELETE FROM table WHERE tests,以及一种方式,将其看做移除行的
SELECT。任何在
WHERE子句中有效的内容在这里都有效。
使用其它表来删除
记得我说过:“DELETE就像
SELECT,但它从表中删除行。” 限制是一次只能从一个表中删除。这意味着为了删除所有宠物,你需要执行一些额外的查询,然后基于它们删除。
一种方法是使用一个子查询,根据你已经编写的查询来选择要所需的 ID。还有其他的方法可以实现它,但是现在你可以根据你所知道的方法来实现它:
DELETE FROM pet WHERE id IN ( SELECT pet.id FROM pet, person_pet, person WHERE person.id = person_pet.person_id AND pet.id = person_pet.pet_id AND person.first_name = "Zed" ); SELECT * FROM pet; SELECT * FROM person_pet; DELETE FROM person_pet WHERE pet_id NOT IN ( SELECT id FROM pet ); SELECT * FROM person_pet;
第 1~8 行是正常起步的
DELETE命令,但是
WHERE子句使用
IN,匹配
pet中的
id列与子查询中返回的表。子查询(也称为子选择)是正常的
SELECT,在尝试寻找人们拥有的宠物时,它应该看起来和以前你做的那个相似。
第 13~16 行中,然后我使用子查询,将任何不存在的宠物从
person_pet表中给删除,使用
NOT IN而不是
IN。
SQL 处理它的方式是以下过程:
运行末尾处括号中的子查询,并创建一个表,带有所有列,就像普通
SELECT一样。
将此表视为一种临时表,来匹配
pet.id列。
浏览
pet表,并删除拥有此临时表中(
IN)的 ID 的任何行。
挑战练习
将所有ex2.sql到
ex7.sql合并到一个文件中,并重执行上述脚本,以便你只需运行一个新文件即可重新创建数据库。
添加一些东西到脚本中,来删除其他宠物,然后再次使用新值插入它们。记住,这不是你通常更新记录的方式,只是为了练习。
练习编写
SELECT命令,然后将它们放在
DELETE WHERE IN中,来删除找到的记录。尝试删除你拥有的任何死亡宠物。
反着操作,删除有死亡宠物的人。
你真的需要删除死的宠物吗?为什么不在
person_pet中移除他们的关系,并标记它们死了?写一个查询,从
person_pet中去除死亡宠物。
深入学习
出于完整性,你需要阅读DELETE文档。
相关文章推荐
- 笨办法学 Python · 续 练习 38:SQL 简介
- 笨办法学 Python · 续 练习 39:SQL 创建
- 笨办法学 Python · 续 练习 40:SQL 读取
- 笨办法学 Python · 续 练习 43:SQL 管理
- 笨办法学 Python · 续 练习 41:SQL 更新
- 笨办法学 Python · 续 练习 35:解释器
- 【python】sql语句插入中内容同时包含单引号和双引号的解决办法
- 笨办法学 Python · 续 练习 45:创建 ORM
- 笨办法学 Python · 续 练习 2:创造力
- 【Oracle】【FAQ】Oracle SQL Developer 编辑区不能删除,后退,空格,复制粘贴等功能都失效的解决办法
- 笨办法学 Python · 续 练习 44:使用 Python 的数据库 API
- #小练习 os.remove() 删除目录文件 分类: python 小练习 2013-05-21 15:49 2774人阅读 评论(0) 收藏
- 【SQL 问题】sql server 2008 不允许保存更改,您所做的更改要求删除并重新创建以下表 的解决办法
- SQL练习1关于插入删除,修改,单表查询
- learn python the hard way(笨办法学python) 练习32 附加练习
- 笨办法学 Python · 续 练习 26:`hexdump`
- 笨办法学 Python · 续 练习 31:正则表达式
- 笨办法学 Python · 续 练习 33:解析器
- 笨办法学 Python · 续 练习 7:`grep`
- 笨办法学 Python · 续 练习 37:小型 BASIC