以前一直是使用關系型數據庫,第一次使用NoSQL,跟大家分享一下我有限的使用心得,希望對像我一樣初使用NoSQL的開發者有所幫助。
首先說說微信小程序云開發里集成的這個NoSQL,官方并沒有說明是哪種NoSQL數據庫,但從開發文檔和暴露的API,還有官方論壇里的討論來看應該是一個簡化版的MongoDB。需要指出的是微信小程序關于云數據庫的開發文檔非常的簡略,對于像我這樣沒有太多NoSQL經驗的用戶,很多時候需要參考MongoDB的相關文檔。
接下來重點談談我在使用這個NoSQL云數據庫時最不適應的一個痛點----文檔級別的原子操作。我們經常要使用到原子操作,來避免當多個用戶同時對同一個field(字段)編輯時發生沖突。我在使用前其實最擔心的痛點是有無schema的區別,但是使用下來發現我挺習慣,也挺喜歡無schema的,后文再詳說。現在具體來看看MongoDB只支持document(文檔)級別的原子操作。對于我來說,這個限制鼓勵我盡量把所有關系都放在一個document里。對此我一開始是有點抗拒的,對于從關系型數據庫過來的人特別不習慣。而更讓我苦惱的是微信小程序云開發集成的這個云數據庫是一個簡化版MongoDB,只提供了非常有限的原子操作指令(command)。對于一些常用的document級別原子操作,我必須構想自己的解決辦法,而沒有提供直接對應的command。以下是兩個我在實際開發中遇到的這類問題及我的解決辦法:
1.
應用場景:對于一個視頻,我需要一個叫total_likes的field(字段),當有用戶點擊“喜歡”時該field遞增1,當有用戶取消“喜歡”時該field遞減1。
痛點:小程序云數據庫只提供了遞增指令的原子操作,沒有提供遞減指令。
const _ = db.command
db.collection('video').doc('video-id').update({
data: {
total_likes: _.inc(1)
}
})
解決辦法:要實現遞減的原子操作,只需在遞增指令里傳入負數,如
data: {
total_likes: _.inc(-1)
}
2.
應用場景:對于一個線上課程,我需要一個叫subscribers的field(字段)來記錄有多少人訂閱了該課程。當有用戶點擊“訂閱”時該字段需記錄該用戶的id,名字及頭像;當有用戶取消“訂閱”時需把該用戶從subscribers字段里刪除。
痛點:我們很自然的會想到用數組(Array)數據類型來維護subscribers這個字段,雖然小程序云數據庫提供了一些針對數組的原子操作,如push,pop,shift和unshfit,可是無法實現取消訂閱這個場景的原子操作。
解決辦法:棄用Array轉而使用對象(object)數據類型來維護subscribers這個字段。最終的數據看起來會是這樣的:
{
"subscribers": {
"userID-1": {
"name": "小明",
"avatar": "https://avatar-1.com"
},
"userID-2": {
"name": "小紅",
"avatar": "https://avatar-2.com"
},
"userID-3": {
"name": "小李",
"avatar": "https://avatar-3.com"
},
...
}
}
當有用戶訂閱時的原子操作:
const subscriber = "subscribers." + user.id;
db.collection('class').where({
_id: 'classID',
}).limit(1).update({
data: {
[subscriber]: {
avatar: user.avatar,
name: user.name,
}
}
})
當有用戶取消訂閱時的原子操作:
const subscriber = "subscribers." + user.id;
db.collection('class').doc('classID').update({
data: {
[subscriber]: _.remove()
}
})
前文說到我很喜歡無schema,因為它非常適合快速迭代開發。而且由于云數據庫使用的是類似JSON的數據結構,對于全棧開發者,基本上可以實現由前端來定義數據結構。這樣的開發流程非常適合小團隊,不需要龐大的并行開發,突出溝通效率和對產品需求的隨機應變。順帶一提的是微信小程序云開發能力是從基礎庫2.2.3開始支持的,但如果要支持所有版本的基礎庫,可以在 app.json / game.json 中增加字段 "cloud": true
本系列第一章:小程序云開發實戰系列01--云環境設置
《Meetup丨活動報名組局》是我最近開發的一個活動報名預約工具小程序,這個系列文章主要來自我在開發這款小程序時的一些體會心得。感興趣的小伙伴可以掃下面的二維碼進入我的小程序。