笨辦法學(xué) Python · 續(xù) 練習(xí) 41:SQL 更新

練習(xí) 41:SQL 更新

原文:Exercise 41: Updating with SQL

譯者:飛龍

協(xié)議:CC BY-NC-SA 4.0

自豪地采用谷歌翻譯

現(xiàn)在争群,你了解了 CRUD 的 CR 部分峰弹,還剩下更新和刪除操作店量。與所有其他 SQL 命令一樣,UPDATE命令遵循類似于DELETE的格式鞠呈,但它會(huì)更改行中的列融师,而不是刪除它們。

UPDATE person SET first_name = "Hilarious Guy"
    WHERE first_name = "Zed";

UPDATE pet SET name = "Fancy Pants"
    WHERE id=0;

SELECT * FROM person;
SELECT * FROM pet;

在上面的代碼中蚁吝,我將我的名字改為"Hilarious Guy"旱爆,因?yàn)檫@更準(zhǔn)確。為了展示我的新綽號(hào)窘茁,我將我的獨(dú)角獸更名為"Fancy Pants"疼鸟。他喜歡它。

這不應(yīng)該很難弄清楚庙曙,只是以防萬一,我拆解第一個(gè):

  • UPDATE開始浩淘,這是你將要更新的表捌朴,這里是person吴攒。
  • 接下來使用SET來說明,哪些列應(yīng)該被設(shè)置為什么值砂蔽。只要你用逗號(hào)分隔洼怔,如first_name = "Zed", last_name = "Shaw",你可以按需更改盡可能多的列左驾。
  • 然后指定一個(gè)WHERE子句镣隶,為每行提供一個(gè)SELECT風(fēng)格的測試集。當(dāng)UPDATE找到匹配時(shí)诡右,它執(zhí)行更新安岂,并會(huì)將列SET為你規(guī)定的樣子。

復(fù)雜表的更新

在上一個(gè)練習(xí)中帆吻,我讓你使用UPDATE執(zhí)行子查詢域那,現(xiàn)在我要求你,將所有我擁有的寵物的名稱更改為"Zed's Pet"猜煮。

SELECT * FROM pet;

UPDATE pet SET name = "Zed's 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;

這是根據(jù)另一個(gè)表的信息更新一個(gè)表的方法次员。還有其他一些方法,可以做同樣的事情王带,但是這樣做是最容易理解淑蔚。

更新數(shù)據(jù)

我將向你展示一種插入數(shù)據(jù)的替代方式,有助于原子地替換一行愕撰。你不一定經(jīng)常需要它刹衫,但是如果必須替換整個(gè)記錄,并且不希望在不使用事務(wù)的情況下執(zhí)行更復(fù)雜的UPDATE盟戏,那么它將會(huì)有所幫助绪妹。

這里,我想用另一個(gè)人替換我的記錄柿究,但僅僅保留 ID邮旷。問題是我必須在事務(wù)中執(zhí)行DELETE/INSERT才能使其成為原子,否則我需要執(zhí)行一個(gè)完整的UPDATE蝇摸。

另一個(gè)更簡單的方法是使用REPLACE命令婶肩,或者將其添加到INSERT作為修飾符。這里有一些 SQL貌夕,我首先無法插入新的記錄律歼,然后我使用這兩種形式的REPLACE來實(shí)現(xiàn)它:

/* This should fail because 0 is already taken. */
INSERT INTO person (id, first_name, last_name, age)
    VALUES (0, 'Frank', 'Smith', 100);

/* We can force it by doing an INSERT OR REPLACE. */
INSERT OR REPLACE INTO person (id, first_name, last_name, age)
    VALUES (0, 'Frank', 'Smith', 100);

SELECT * FROM person;

/* And shorthand for that is just REPLACE. */
REPLACE INTO person (id, first_name, last_name, age)
    VALUES (0, 'Zed', 'Shaw', 37);

/* Now you can see I'm back. */
SELECT * FROM person;

挑戰(zhàn)練習(xí)

  • 使用UPDATE,通過我的person.id啡专,將我的名字改回"Zed"险毁。
  • 寫一個(gè)UPDATE,將任何死亡動(dòng)物重命名為"DECEASED"。如果你嘗試說他們是"DEAD"畔况,它會(huì)失敗鲸鹦,因?yàn)?SQL 會(huì)認(rèn)為你的意思是,將其設(shè)置為名為"DEAD"的列跷跪,這不是你想要的馋嗜。
  • 嘗試使用一個(gè)子查詢,比如在DELETE中吵瞻。
  • 訪問 SQL As Understood By SQLite 頁面葛菇,并開始閱讀CREATE TABLEDROP TABLE橡羞,INSERT眯停,DELETESELECTUPDATE的文檔尉姨。
  • 嘗試在這些文檔中找到一些有趣的事情庵朝,并記錄你不明白的事情,以便你可以稍后研究它們又厉。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末九府,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子覆致,更是在濱河造成了極大的恐慌侄旬,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,734評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件煌妈,死亡現(xiàn)場離奇詭異儡羔,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)璧诵,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門汰蜘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人之宿,你說我怎么就攤上這事族操。” “怎么了比被?”我有些...
    開封第一講書人閱讀 164,133評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵色难,是天一觀的道長。 經(jīng)常有香客問我等缀,道長枷莉,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,532評(píng)論 1 293
  • 正文 為了忘掉前任尺迂,我火速辦了婚禮笤妙,結(jié)果婚禮上冒掌,老公的妹妹穿的比我還像新娘。我一直安慰自己危喉,他們只是感情好宋渔,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,585評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著辜限,像睡著了一般。 火紅的嫁衣襯著肌膚如雪严蓖。 梳的紋絲不亂的頭發(fā)上薄嫡,一...
    開封第一講書人閱讀 51,462評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音颗胡,去河邊找鬼羹呵。 笑死羞迷,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播柒爵,決...
    沈念sama閱讀 40,262評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼鹦蠕!你這毒婦竟也來了士败?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,153評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤俘枫,失蹤者是張志新(化名)和其女友劉穎腥沽,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鸠蚪,經(jīng)...
    沈念sama閱讀 45,587評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡今阳,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,792評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了茅信。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片盾舌。...
    茶點(diǎn)故事閱讀 39,919評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖蘸鲸,靈堂內(nèi)的尸體忽然破棺而出妖谴,到底是詐尸還是另有隱情,我是刑警寧澤棚贾,帶...
    沈念sama閱讀 35,635評(píng)論 5 345
  • 正文 年R本政府宣布窖维,位于F島的核電站,受9級(jí)特大地震影響妙痹,放射性物質(zhì)發(fā)生泄漏铸史。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,237評(píng)論 3 329
  • 文/蒙蒙 一怯伊、第九天 我趴在偏房一處隱蔽的房頂上張望琳轿。 院中可真熱鬧,春花似錦、人聲如沸崭篡。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,855評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽琉闪。三九已至迹炼,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間颠毙,已是汗流浹背斯入。 一陣腳步聲響...
    開封第一講書人閱讀 32,983評(píng)論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蛀蜜,地道東北人刻两。 一個(gè)月前我還...
    沈念sama閱讀 48,048評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像滴某,于是被迫代替她去往敵國和親磅摹。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,864評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容