SQLAlchemy:根据列值在表中创建关系

如何解决SQLAlchemy:根据列值在表中创建关系

我是 sqlAlchemy 的新手。我一直在尝试创建一个数据库,其中包含一个包含核心信息的主表,例如:

Actor:
name   dob     fun_fact             extra_info
MD     7/4/75 "likes water skiing"  stuntman
DJ     7/4/76 "really strong"       charity
MBJ    7/4/76 "very friendly"       stuntman
.....

基于 extra_info 列,我想要包含与 extra_info 值相关的数据的单独表。

与 MD 和 MBJ 相关的数据是与他们合作的特技演员:

Stuntmen:
id   stuntman   number_of_stunts  number_injuries
MD   JJ         49                3
MBJ  JA         20                1
....

对于完全不同类型的数据,我还有一个单独的表格——演员与之合作的慈善机构(MD 和 MBJ 不与慈善机构合作,因此这与他们无关)。

Charity_work
id   charity_name         funds_raised
DJ   "homes for puppies"  "$5000"
....

为了制作这种数据库,我尝试使用表类继承:

class Actor(Base):
    __tablename__ = 'actors'
    id = Column(Integer,primary_key=True)
    name = Column(Text,nullable=False)
    dob = Column(Integer,nullable=False)
    fun_fact = Column(Text,nullable=False)
    extra_info = Column(String(50))
    file_id = Column(ForeignKey('movies_industry.id'))
    __mapper_args__ = {
        'polymorphic_identity':'generic','polymorphic_on':extra_info
    }
    def __init__(self,name,dob,fun_fact,extra_info):
        self.name = name
        self.dob = dob
        self.fun_fact = fun_fact
        self.extra_info = extra_info

class Stuntman(Actor):
    stuntman = Column(Text,nullable=False)
    number_of_stunts = Column(Integer,nullable=False)
    number_of_injuries = Column(Integer,nullable=False)
    __mapper_args__ = {
        'polymorphic_identity':'stuntman'
    }
    __tablename__ = 'stuntmen'
    id = Column(None,ForeignKey('actors.id'),primary_key=True)
    def __init__(self,stuntman,number_of_stunts,number_of_injuries):
        self.stuntman = stuntman
        self.number_of_stunts= number_of_stunts
        self.number_of_injuries=number_of_injuries

class Charity(Actor):
    charity_name = Column(Text,nullable=False)
    funds_raised = Column(Text,nullable=False)
    __mapper_args__ = {
        'polymorphic_identity':'charity'
    }
    __tablename__ = 'charities'
    id = Column(None,charity_name,funds_raised):
        self.charity_name = charity_name
        self.funds_raised = funds_raised

完成后 - 我必须从不同来源读取数据并将数据添加数据库中:

df=pd.read_csv('actors_stuntmen.csv')
name   dob     fun_fact             name   number_stunts   number_injuries 
MD     7/4/75 "likes water skiing"  ....
DJ     7/4/76 "really strong"       ....
MBJ    7/4/76 "very friendly"       ....
.....


movie_industry=Movie_Industry("America") #ignore this line
for row in df.itertuples():
    actor=Actor(row[1],row[2],row[3],'stuntman')
    stuntman=Stuntman(row[4],row[5],row[6])
    movies_industry.actors.append(actor)

但是,当我尝试将此数据提交到数据库时出现错误

session.add(movie_industry)
session.add(actor)
session.add(stuntman)
session.commit()

    /path/lib/python3.7/site-packages/sqlalchemy/orm/mapper.py:1606: SAWarning: Flushing object <Loci at 0x2b523ea38750> with incompatible polymorphic identity 'state'; the object may not refresh and/or load correctly (this warning may be suppressed after 10 occurrences)
  (state_str(extra_info),dict_[polymorphic_key]),[sql: INSERT INTO Loci (name,extra_info) VALUES (?,?,?)]
[parameters: (None,None,'stuntman')]

总的来说,我想要一个数据库,我可以在其中添加数据并根据列 extra_info 的值-将必要的信息添加到适当的表中,并在这些表的行之间建立适当的链接-见下文:

enter image description here

希望得到一些关于我哪里出错的指导 - 或者是否有我不知道的方法

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?