sqlalchemy expunge的简单使用

在 SQLAlchemy 中,expunge 是一个方法,用于从当前 Session 的状态中移除一个对象,使其不再与 Session 关联。这意味着,尽管对象本身可能仍然存在,但它将不再被 Session 跟踪其状态变化。

当你调用 expunge 方法时,你传递一个已经添加到 Session 中的对象作为参数。之后,这个对象将不再被视为 Session 的一部分,任何对其状态的更改都不会被 Session 捕获,并且在后续的 flushcommit 操作中也不会被同步到数据库。

以下是 expunge 方法的一个简单示例:

python 复制代码
from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker

Base = declarative_base()

class User(Base):
    __tablename__ = 'users'
    id = Column(Integer, primary_key=True)
    name = Column(String)

# 假设数据库已经配置好,并且表已经创建
engine = create_engine('sqlite:///example.db')
Session = sessionmaker(bind=engine)
session = Session()

# 创建一个新的 User 对象并添加到 session
new_user = User(name='Alice')
session.add(new_user)
session.flush()  # 将对象同步到数据库,但此时事务还未提交

# 现在,从 session 中移除这个对象
session.expunge(new_user)

# new_user 对象现在不再与 session 关联
# 对 new_user 的任何更改都不会被 session 跟踪,也不会被同步到数据库

# 提交事务(由于已经 expunge,new_user 的状态变化不会被提交)
session.commit()

在这个例子中,我们首先创建了一个新的 User 对象并将其添加到 Session 中。然后,我们调用 flush 方法将对象的状态同步到数据库(但此时事务还未提交)。接着,我们调用 expunge 方法从 Session 中移除这个对象。最后,我们提交事务,但由于 new_user 已经被 expunge 了,所以对其的任何更改都不会被提交到数据库。

请注意,expunge 并不会从数据库中删除对象,它只是从 Session 的状态中移除对象。如果你想要从数据库中删除对象,你应该使用 delete 方法。

相关推荐
xiaoliuliu123451 分钟前
treeNMS-1.7.5部署步骤详解(附Java环境准备与数据库配置)
java·开发语言·数据库
数据知道2 分钟前
MongoDB 更新操作符 `$set` 与 `$unset`:精准修改字段与删除字段
数据库·mongodb
数据知道2 分钟前
MongoDB 数值更新原子操作:`$inc` 实现点赞、计数器等高并发原子操作
数据库·算法·mongodb
jnrjian11 分钟前
Oracle 共享池 库缓存下的 Library Cache Lock
数据库·缓存·oracle
科技块儿11 分钟前
开发者需要为网站或应用集成IP归属地显示功能,如何选择可靠的数据源?
服务器·网络·数据库·tcp/ip·edge·ip
没有bug.的程序员14 分钟前
金融风控系统:实时规则引擎内核、决策树物理建模与 Drools 性能压榨
java·数据库·决策树·金融·drools·物理建模·实时规则
SuniaWang21 分钟前
Milvus 深度解析:为 AI 而生的云原生向量数据库
数据库·人工智能·milvus
北京_小杰子29 分钟前
Windows10本地安装SQLserver数据库连接的过程
数据库·windows·sqlserver·php
堕27431 分钟前
MySQL数据库《基础篇--表的增删改查操作CRUD(3)》
数据库·mysql
Xin_z_31 分钟前
数据库连接未释放导致表被锁问题排查与处理
数据库