27 lines
1.2 KiB
Python
27 lines
1.2 KiB
Python
from sqlalchemy import create_engine, Column, Integer, String, Float, DateTime, ForeignKey, Text
|
|
from sqlalchemy.orm import declarative_base, relationship
|
|
|
|
Base = declarative_base()
|
|
|
|
class Bundle(Base):
|
|
__tablename__ = 'bundles'
|
|
id = Column(Integer, primary_key=True)
|
|
machine_name = Column(String, unique=True)
|
|
human_name = Column(String)
|
|
current_version_id = Column(Integer, ForeignKey('bundle_versions.id'))
|
|
current_version = relationship("BundleVersion", uselist=False, foreign_keys=[current_version_id], post_update=True)
|
|
versions = relationship("BundleVersion", back_populates="bundle", foreign_keys=lambda: [BundleVersion.bundle_id])
|
|
sales_history = relationship("BundleSalesHistory", back_populates="bundle")
|
|
items = relationship("BundleItem", back_populates="bundle")
|
|
|
|
class BundleVersion(Base):
|
|
__tablename__ = 'bundle_versions'
|
|
id = Column(Integer, primary_key=True)
|
|
bundle_id = Column(Integer, ForeignKey('bundles.id'))
|
|
version_hash = Column(String)
|
|
version_data = Column(Text)
|
|
timestamp = Column(DateTime)
|
|
bundle = relationship("Bundle", back_populates="versions", foreign_keys=[bundle_id])
|
|
|
|
# ... weitere Modelle (BundleSalesHistory, BundleItem, ...)
|