PostgreSQL 的 RETURNING 子句

你知道 PostgreSQL 的 INSERT/UPDATE/DELETE 語句(statement)支援 RETURNING 子句(clause)嗎?

PostgreSQL 的 INSERT 可以這樣寫:

INSERT comment (name, text) VALUES ('JoJo', 'Hi')
RETURNING id;

支援 RETURNING 子句的好處是像這種由資料庫產生 Id 的資料,可以省下 1 個再去查詢剛剛產生的 Id 是什麼的 Query, 不僅可以少寫一段程式,還可以提升資料庫效能,整個提升開發者體驗!

實際上 RETURNING 還允許使用與 SELECT 相同的語法,包含取得多個欄位、重新命名欄位、計算欄位值等等,應用上也很彈性。

大家可能會想為什麼 DELETE 為什麼需要 RETURNING 子句,用在 DELETE 語句時, RETURNING 會回傳被刪除資料內容,如果有需要事先對資料進行備份的話,也就不需要在刪除之前額外多執行一次 Query 將資料查詢好。

以上就是 PostgreSQL 的 RETURNING 子句介紹,從這個小地方我個人蠻看好 PostgreSQL 的長期發展!

Facebook Threads X

對抗久坐職業傷害

研究指出每天增加 2 小時坐著的時間,會增加大腸癌、心臟疾病、肺癌的風險,也造成肩頸、腰背疼痛等常見問題。

然而對抗這些問題,卻只需要工作時定期休息跟伸展身體即可!

你想輕鬆改變現狀嗎?試試看我們的 PomodoRoll 番茄鐘吧! PomodoRoll 番茄鐘會根據你所設定的專注時間,定期建議你 1 項辦公族適用的伸展運動,幫助你打敗久坐所帶來的傷害!

贊助我們的創作

看完這篇文章了嗎? 休息一下,喝杯咖啡吧!

如果你覺得 MyApollo 有讓你獲得實用的資訊,希望能看到更多的技術分享,邀請你贊助我們一杯咖啡,讓我們有更多的動力與精力繼續提供高品質的文章,感謝你的支持!