mongo数据库的事务操作
一:mongo数据库的版本在4.0以上
二:以pymongo为例
from pymongo import MongoClient class MongoTest(object): def __init__(self): self.conn = MongoClient(host='xxx', port=xxx) def transaction_test_normal(self): """正常给两条数据库插入两条数据""" # self.conn["test1"]["t1"] ql_test1指的是数据库名字 test1指的是集合名字 t1 = self.conn["ql_test"]["test1"] t2 = self.conn["ql_test"]["test2"] # 1. pymongo的client开启事务 with self.conn.start_session(causal_consistency=True) as session: with session.start_transaction(): ressult1 = t1.insert_one(document={"name":"beijing"},session=session) ressult2 = t2.insert_one(document={"name":"shanghai"},session=session) # 返回两条插入数据的_id的值 print(ressult1.inserted_id,ressult2.inserted_id) def transaction_test_abort(self): """事务删除两条数据,引发异常后,两条数据都未发生改变""" t1 = self.conn["ql_test"]["test1"] t2 = self.conn["ql_test"]["test2"] with self.conn.start_session(causal_consistency=True) as session: with session.start_transaction(): ressult1 = t1.delete_one({"name":"beijing"},session=session) print(1/0) ressult2 = t2.delete_one({"name":"shanghai"},session=session) print(ressult1.deleted_count,ressult2.deleted_count) def test1(self): """插入一条数据成功后,删除一条数据,故意抛出异常,看插入是否成功""" t1 = self.conn["ql_test"]["test1"] t2 = self.conn["ql_test"]["test2"] with self.conn.start_session(causal_consistency=True) as session: with session.start_transaction(): # xian未插入成功 ressult1 = t1.insert_one({"name": "xian"}, session=session) print(1 / 0) ressult2 = t2.delete_one({"name": "guandong"}, session=session) print(ressult1.inserted_id, ressult2.deleted_count) def test2(self): """ 更新第一条数据,更新第二条数据,故意抛出异常,看是否更新成功--- 1. 不能使用update方法了,必须使用find_one_and_update 2. find_one_and_update也有upsert=True选项,不存在就执行插入操作,存在就不做任何操作 """ t1 = self.conn["ql_test"]["test1"] t2 = self.conn["ql_test"]["test2"] with self.conn.start_session(causal_consistency=True) as session: with session.start_transaction(): # r1 = t1.find_one_and_update({"name":"xian666"},{"$set":{"name":"xian"}},session=session) print(1 / 0) r2 = t2.find_one_and_update({"name":"chongqing"},{"$set":{"name":"chongqing666"}},session=session) print(r1,r2) m = MongoTest() m.test2()
# TODO
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· dotnet 源代码生成器分析器入门
· ASP.NET Core 模型验证消息的本地化新姿势
· 对象命名为何需要避免'-er'和'-or'后缀
· SQL Server如何跟踪自动统计信息更新?
· AI与.NET技术实操系列:使用Catalyst进行自然语言处理
· dotnet 源代码生成器分析器入门
· 官方的 MCP C# SDK:csharp-sdk
· 一款 .NET 开源、功能强大的远程连接管理工具,支持 RDP、VNC、SSH 等多种主流协议!
· 一步一步教你部署ktransformers,大内存单显卡用上Deepseek-R1
· 一次Java后端服务间歇性响应慢的问题排查记录