溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

用PostgreSQL的五個(gè)優(yōu)點(diǎn)分別是什么

發(fā)布時(shí)間:2021-11-17 14:56:33 來(lái)源:億速云 閱讀:134 作者:柒染 欄目:web開發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)用PostgreSQL的五個(gè)優(yōu)點(diǎn)分別是什么,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

先不管 Instagram 最近的負(fù)成長(zhǎng)以及反駁,剛剛在 Instagram Engineering 上看到對(duì) PostgreSQL 的稱贊:「Handling Growth with Postgres: 5 Tips From Instagram」

Facebook在MySQL的領(lǐng)域里的實(shí)力以及貢獻(xiàn)度可是數(shù)一數(shù)二,但 Instagram 在被 Facebook 買下後仍然繼續(xù)使用 PostgreSQL,總是有些原因存在… 雖然真正的原因不一定是技術(shù),但這篇試著用技術(shù)解釋的內(nèi)容還是可以看一看,了解 PostgreSQL 有哪些特點(diǎn)

第一個(gè)是講 partial indexes,這與 MySQL community 常講的 partial index 是不同的東西。

MySQL 的 partial index 是指只 index 某個(gè)欄位的一部分,像是 VARCHAR(255) 里面只 index  前面的 10 chars;而 PostgreSQL 的 partial indexes 則是指符合某個(gè)條件的 row 才 index。

第二個(gè)是 functional indexes,可以針對(duì)欄位計(jì)算後再 index。MySQL 的 partial index 在 PostgreSQL 里可以用 functional indexes + substr() 達(dá)到相同的效果,而且還有其他 function 可以用,花樣更多。

兩個(gè)都是 MySQL 做不到 (或是做不好),但 PostgreSQL 做的不錯(cuò)的。一般在 MySQL 要達(dá)到 PostgreSQL 的這兩個(gè)功能需要另外開一個(gè)欄位,在里面儲(chǔ)存去正規(guī)化后的值,再對(duì)這個(gè)欄位 index。

第三個(gè)是講 defrag 的事情,這部份 MySQL 也可以用第三方的工具 Percona Toolkit 搞定。

第四個(gè)講 PostgreSQL 的 Write-Ahead Log,有點(diǎn)像是 MySQL 的 binlog。

最后一個(gè)講 Python上的psycopg2。

看來(lái)看去就是 index 那塊最明顯。可以直接減少去正規(guī)化的欄位

關(guān)于用PostgreSQL的五個(gè)優(yōu)點(diǎn)分別是什么就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI