譯者 | 陳峻
策劃 | 云昭
如今,程序員們可以選用多種編程語言,來創(chuàng)建在線平臺、網(wǎng)站和應用程序。其中,在編程社區(qū)中,廣受不同開發(fā)背景的人員所推崇的一種流行語言,便是React Native。它是由Facebook的JavaScript工具包所構(gòu)建,適合為移動平臺、而非Web,設(shè)計和創(chuàng)建獨特的用戶界面。目前,React Native已被廣泛地運用在采用JavaScript的框架,并為iOS和Android平臺構(gòu)建移動應用的項目中。
可以說,該領(lǐng)域的開發(fā)者不但需要了解JavaScript和API服務(wù)、而且要能夠構(gòu)建前端的UI,維護跨平臺的兼容性、以及整合基礎(chǔ)架構(gòu)與其他應用。下圖展示了歷年來,時下各種編程語言,在項目中被使用的占比分布。
目前,適合React Native應用的數(shù)據(jù)庫有:Async Storage、SQLite、Realm、以及PouchDB等。下面,我將和大家一起深入討論各種數(shù)據(jù)庫的特性和優(yōu)缺點,并最終給出為React Native應用進行選擇時的建議。
MMKV存儲
由C++開發(fā)的MMKV存儲具有快速高效的特點,可方便您在React Native應用中快速地保存數(shù)據(jù)。同時,該數(shù)據(jù)庫非常輕巧。它在Android上僅占50K空間,而在iOS上只有30K。如果被打包的話,其體積會更小。此外,MMKV不但支持redux-persist(持久化),而且允許用戶保存任何形式(無論是否加密)的數(shù)據(jù)。
特征如下:
- 支持加密(安全存儲)。
- 支持多實例(將用戶數(shù)據(jù)與全局數(shù)據(jù)分開)。
- 自定義存儲位置。
- 由于一切都是用C++編寫的,因此具有高性能。
- 比Async Storage快大約30倍。
- 使用JSI框架,而不是舊的“橋”模式。
- 支持iOS、Android和Web。
- 易于使用React Hooks的API。
Realm數(shù)據(jù)庫
由于可以使用動態(tài)映射到完整且專有的數(shù)據(jù)庫引擎,基于SQLite的Realm能夠處理各種原生的JavaScript對象,并在保持性能的同時,提供一套簡單的API。同時,Realm允許開發(fā)者創(chuàng)建各種高級搜索、復雜的數(shù)據(jù)表示、以及在圖表中的事物鏈接。
Realm在Android中屬于輕量級數(shù)據(jù)庫。與下文將討論的SQLite相比,Realm不但使用的內(nèi)存更少,而且在讀寫數(shù)據(jù)等常見操作上的速度更快。此外,它還具有極其豐富的功能集。
特征如下:
- 由于Realm屬于對象存儲,因此對象之間的關(guān)系可以通過各種“鏈接”來實現(xiàn)。
- 每個“鏈接”都能夠創(chuàng)建一個與鏈接到當前對象的“反向鏈接”映射。
- Realm可以更新其實例版本。
- Realm帶有零拷貝(zero-copy)架構(gòu),以及延遲加載(lazy-loaded)式的數(shù)據(jù)訪問。
SQLite
作為C語言數(shù)據(jù)存儲庫的SQLite,在移動應用程序中,特別適用于離線應用。許多平臺都以簡便的設(shè)置方式,提供了開箱即用的SQLite支持。而作為最著名的免費Android開發(fā)數(shù)據(jù)庫之一,它不但具有開源的顯著特點,而且可以滿足開發(fā)人員廣泛的項目需求。
特征
- 能夠在iOS和Android上提供相同JavaScript API。
- 在各種Java和Native模式下,以及Android中都可以被使用。
- 其簡單的回調(diào)(callback)和Promises可以被用于連接JavaScript里的SQL事務(wù)。
- 可以從應用程序包和沙箱中,導入預填充的SQLite數(shù)據(jù)庫。
- Windows能夠像在iOS和Android上一樣,支持回調(diào)API。
Firebase
Firebase實時數(shù)據(jù)庫是一個由Google支持的應用開發(fā)平臺,可允許開發(fā)人員為iOS、Android和web創(chuàng)建各種應用。而作為一種基于云端的NoSQL數(shù)據(jù)庫,F(xiàn)irebase可以通過提供分析跟蹤、報告、應用問題修復、以及市場和產(chǎn)品實驗功能(experimentation capabilities)等服務(wù),在用戶之間實現(xiàn)實時存儲和數(shù)據(jù)同步。
特征
- 即使應用處于離線狀態(tài),數(shù)據(jù)也能在所有客戶端之間實時同步。
- 可以讓開發(fā)人員更專注于打造出色的用戶體驗,而無需管理服務(wù)器。
- Firebase為您準備好了通用的服務(wù)器、API和數(shù)據(jù)存儲,您只需按照實際需求進行修改即可,而不需重新編寫。
- 按照云托管數(shù)據(jù)庫的需求,F(xiàn)irebase可以將數(shù)據(jù)以JSON格式進行存儲,并進一步持續(xù)同步到每個關(guān)聯(lián)的客戶端上。
- 作為基于云服務(wù)的數(shù)據(jù)庫,它可被用于管理應用程序的數(shù)據(jù),并提供快速的數(shù)據(jù)結(jié)果。
WatermelonDB
在React Native和React的在線項目中,WatermelonDB提供了一種管理用戶數(shù)據(jù)的新方法。它是專為創(chuàng)建復雜的React Native應用而設(shè)計的,且十分重視應用的實際性能。簡單而言,由于Watermelon的架構(gòu)與數(shù)據(jù)庫無關(guān),因此開發(fā)者可以橫跨多個平臺使用它,并能達到快速啟動軟件的效果。此外,作為一個高級數(shù)據(jù)管理層,Watermelon還可以根據(jù)平臺的要求,連接到任何React原生的數(shù)據(jù)庫層面上。
特征
- 由于使用延遲加載,Watermelon DB可以只在被請求時才加載數(shù)據(jù)。據(jù)此,應用程序的可擴展性可以得到大幅增強。
- 由于所有的查詢都是在其不同的線程上完成的,因此大多數(shù)查詢只需不到1毫秒的時間。
- 無論后端的數(shù)據(jù)體量有多大,您都可以立即啟動應用程序。
- 它能夠與iOS、Android和web相兼容。
- 它使用JavaScript的靜態(tài)類型檢查器,通過Flow的方式進行靜態(tài)類型轉(zhuǎn)化。
- 它具有快速、異步、多線程和高度緩存等特性,也可與同步引擎協(xié)同工作,以保持原生本地數(shù)據(jù)庫與遠程數(shù)據(jù)庫的同步。
PouchDB
PouchDB是一個基于Apache CouchDB的開源JavaScript類型的數(shù)據(jù)庫。它針對在瀏覽器中的各種使用場景進行了優(yōu)化。PouchDB在瀏覽器中會使用IndexedDB和WebSQL在本地存儲數(shù)據(jù),并且持續(xù)實現(xiàn)本地和遠程數(shù)據(jù)庫的交互。據(jù)此,PouchDB可以幫助Web開發(fā)人員創(chuàng)建具有離線和在線等效功能的應用。也就是說,它允許應用在離線時,將數(shù)據(jù)保存在本地,而在應用重新上線后,再與CouchDB和其他兼容的服務(wù)器相同步,以確保用戶的數(shù)據(jù)始終為最新。
特征
- 由于PouchDB提供的API在所有瀏覽器中都是相同的,因此它可以在各種瀏覽器中被流暢地使用。
- 如果您對編程語言有所了解,那么學習和理解PouchDB并非難事。
- 作為一種輕量級的API,我們可以方便地使用script標簽來包含它。
Vasern
Vasern是一種基于鏈接一致性的鍵-值存儲式React Native數(shù)據(jù)存儲系統(tǒng)。其目標是提供一個開源、且對開發(fā)人員友好的端到端數(shù)據(jù)庫系統(tǒng)。而且,由于其數(shù)據(jù)引擎是從頭開始創(chuàng)建的,因此Vasern提供了原生的性能。
特征
- 它通過UTF-8編碼來支持各種語言。
- 能夠支持字符串、整數(shù)、雙精度、日期時間、以及引用等基本數(shù)據(jù)類型。
- 可以通過schema來創(chuàng)建、更新、查詢和刪除各種記錄。
MySQL、MongoDB和DynamoDB
一些小型組織往往會使用MySQL、MongoDB和DynamoDB等服務(wù)器端數(shù)據(jù)庫,進行React Native的應用開發(fā)。三者的比較如下:
開發(fā)人員在選擇數(shù)據(jù)庫之前需要考慮什么?
眾所周知,在中小型軟件運行的過程時,數(shù)據(jù)往往是被保存在變量之中的。不過,當程序重啟時,變量則會因為恢復初始值,而導致數(shù)據(jù)的丟失。對此,我們需要數(shù)據(jù)庫在能夠起到很好的數(shù)據(jù)存儲、保持、以及在程序重啟后的持續(xù)檢索等作用。通常,我們可以在為React Native應用選擇數(shù)據(jù)庫之前,考慮如下方面:
- 應確保數(shù)據(jù)庫具有足夠的內(nèi)存,可供軟件的執(zhí)行。
- 選擇可以處理復雜數(shù)據(jù)結(jié)構(gòu)(如整篇文檔或?qū)ο螅┑臄?shù)據(jù)庫。
- 當用戶從離線恢復為在線狀態(tài)時,應能夠通過集成來實現(xiàn)數(shù)據(jù)庫中數(shù)據(jù)的同步。
- 容易實現(xiàn)應用與數(shù)據(jù)庫的集成。
小結(jié)
上述介紹的各種數(shù)據(jù)庫分別有著自己的一組特性和優(yōu)缺點。因此,在為React Native應用選擇合適的數(shù)據(jù)庫時,開發(fā)人員應當清楚地了解自己的項目目標和應用需求,通過試用、比較和深入研究,從中選擇最符合要求的數(shù)據(jù)庫。
原文鏈接:https://dzone.com/articles/how-developers-need-to-choose-the-right-database-f
譯者介紹
陳峻 (Julian Chen),51CTO社區(qū)編輯,具有十多年的IT項目實施經(jīng)驗,善于對內(nèi)外部資源與風險實施管控,專注傳播網(wǎng)絡(luò)與信息安全知識與經(jīng)驗;持續(xù)以博文、專題和譯文等形式,分享前沿技術(shù)與新知;經(jīng)常以線上、線下等方式,開展信息安全類培訓與授課。