在MongoDB中,事务是一组操作,这些操作必须一起执行,或者全部回滚。MongoDB 4.0版本引入了多文档事务支持,可以使用MongoDB的驱动程序或mongo shell执行事务。
以下是使用MongoDB驱动程序执行事务的一般步骤:
1 创建MongoClient实例并指定uri:
from pymongo import MongoClient
uri = 'mongodb://localhost:27017/mydatabase'
client = MongoClient(uri)
2 获取MongoDB数据库和集合:
db = client.get_database('mydatabase')
collection = db.my_collection
3 开始事务:
with client.start_session() as session:
with session.start_transaction():
# 在事务中执行操作
collection.insert_one({'_id': 1, 'name': 'Alice'})
collection.update_one({'_id': 1}, {'$set': {'age': 30}})
4 提交或回滚事务:
session.commit_transaction()
# 或者
session.abort_transaction()
在mongo shell中执行事务也很简单,可以使用以下命令:
session = db.getMongo().startSession();
session.startTransaction();
// 在事务中执行操作
db.collection.insertOne({_id: 1, name: 'Alice'});
db.collection.updateOne({_id: 1}, {$set: {age: 30}});
session.commitTransaction();
// 或者
session.abortTransaction();
在执行事务之前,需要确保MongoDB实例是运行在副本集模式下,并且写入操作必须在相同的分片键上执行。