确定SQLAlchemy对象上哪些字段是脏的

时间:2015-02-05 20:05:23

标签: postgresql sqlalchemy

我知道,使用SQLAlchemy的session对象,我可以调用session.dirty来获取需要提交到数据库的所有对象。但是,如何确定任何一个对象上的哪些特定字段是脏的?有没有一种方法可以调用返回这些字段的特定对象?或者也许我可以将对象传递给session的一个类方法来获取它?

1 个答案:

答案 0 :(得分:4)

来自History类的示例:

from sqlalchemy import inspect

hist = inspect(myobject).attrs.myattribute.history

如果要检查给定对象实例的所有已定义属性,您可能会执行以下操作:

def print_changes(myobj):
    from sqlalchemy.orm import class_mapper
    from sqlalchemy import inspect
    inspr = inspect(myobj)
    attrs = class_mapper(myobj.__class__).column_attrs  # exclude relationships
    for attr in attrs:
        hist = getattr(inspr.attrs, attr.key).history
        print(attr.key, hist.has_changes())