我无法创建一个简单的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".)
答案 0 :(得分:2)
这是一个操作顺序问题。我没有仔细阅读输出。基本上我试图在创建任何用户之前分配用户。