sqlalchemy mixin、外键和关系

2024-04-19

我在创建一个简单的 mixin 时遇到问题,我计划在一堆 sqlalchemy 声明类上使用它。基本想法是我想要一个创建/修改时间戳和一个创建/修改用户存储在多个表上。 mixin 位于其自己的文件 (global_mixins.py) 中,并且该类被导入到需要 mixin 的每个模型文件中。当我运行数据导入时,我在代码下方收到错误。

class TimeUserMixin(object):
    create_time = Column(DateTime,default=datetime.datetime.now,nullable=False)
    modify_time = Column(DateTime,default=datetime.datetime.now,
                    onupdate=datetime.datetime.now,nullable=False)

    @declared_attr
    def create_user_id(cls):
        return Column(Integer,ForeignKey('tg_user.user_id'),
                      default=cls.get_user_id,nullable=False)

    @declared_attr
    def modify_user_id(cls):
        return Column(Integer,ForeignKey('tg_user.user_id'),
                      default=cls.get_user_id,onupdate=cls.get_user_id,nullable=False)

    @declared_attr
    def create_user(cls):
        return relation('User',primaryjoin='%s.create_user_id == User.user_id'%cls.__name__)

    @declared_attr
    def modify_user(cls):
        return relation('User',primaryjoin='%s.modify_user_id == User.user_id'%cls.__name__)

    @classmethod
    def get_user_id(cls):
        #will eventually return user id if logged in or a generic system user.
        return 1

Error(DETAIL:  Key (create_user_id)=(1) is not present in table "tg_user".)

这是一个操作顺序问题。我没有仔细阅读输出。基本上我试图在创建任何用户之前分配一个用户。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

sqlalchemy mixin、外键和关系 的相关文章

随机推荐