MongoDB是一個不支持悲觀鎖的數據庫,它更傾向于使用樂觀鎖的方式來處理并發訪問沖突。
樂觀鎖的實現方式如下:
version
。以下是一個使用MongoDB樂觀鎖的示例代碼:
// 假設使用mongoose作為MongoDB的ODM(對象文檔映射)工具
const mongoose = require('mongoose');
// 創建Schema
const bookSchema = new mongoose.Schema({
name: String,
author: String,
version: { type: Number, default: 0 }
});
// 創建Model
const Book = mongoose.model('Book', bookSchema);
async function updateBook(bookId, newName) {
// 查詢文檔
const book = await Book.findById(bookId);
// 更新文檔
book.name = newName;
book.version += 1;
// 使用版本號作為查詢條件更新文檔
const result = await Book.updateOne({ _id: bookId, version: book.version - 1 }, { $set: { name: newName, version: book.version } });
if (result.nModified === 0) {
// 更新失敗,處理沖突
throw new Error('Update conflict');
}
}
// 使用示例
updateBook('bookId', 'New Name').then(() => {
console.log('Update success');
}).catch((error) => {
console.error('Update failed:', error);
});
這種樂觀鎖的實現方式可以通過版本號來檢測并發沖突,并在更新失敗時處理沖突。