Skip to content

Support PostgreSQL Table Inhertiance  #336

Open
@kiitosu

Description

@kiitosu

Things to check first

  • I have searched the existing issues and didn't find my bug already reported there

  • I have checked that my bug is still present in the latest release

Sqlacodegen version

3.0.0rc5

SQLAlchemy version

2.0.29

RDBMS vendor

PostgreSQL

What happened?

When using sqlacodegen to generate ORM classes from an existing database schema, the child table ORM classes that inherit from base tables are not created. This issue occurs when there are tables using SQLAlchemy inheritance.

Is there any way to codegen child tables?

Database schema for reproducing the bug

Up migrateion to reproduce is like below.

create schema "test";

CREATE TABLE "test"."base" ("base" integer NOT NULL, PRIMARY KEY ("base") );COMMENT ON TABLE "test"."base" IS E'base';

CREATE TABLE test.sub (
    sub_data integer
) INHERITS (test.base);

Generated code.

# Using geoalchemy2 0.14.7
from sqlalchemy import Column, Integer, PrimaryKeyConstraint, Table
from sqlalchemy.orm import DeclarativeBase, Mapped, mapped_column

class Base(DeclarativeBase):
    pass


class Base(Base):
    __tablename__ = 'base'
    __table_args__ = (
        PrimaryKeyConstraint('base', name='base_pkey'),
        {'comment': 'base', 'schema': 'test'}
    )

    base: Mapped[int] = mapped_column(Integer, primary_key=True)


t_sub = Table(
    'sub', Base.metadata,
    Column('base', Integer, nullable=False),
    Column('sub_data', Integer),
    schema='test'
)

Metadata

Metadata

Assignees

No one assigned

    Labels

    Projects

    No projects

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions