Skip to content

Latest commit

 

History

History
167 lines (129 loc) · 6.8 KB

CHANGES.rst

File metadata and controls

167 lines (129 loc) · 6.8 KB

Version history

UNRELEASED

  • Added support for generating SQLModel classes (PR by Andrii Khirilov)
  • Fixed code generation when a single-column index is unique or does not match the dialect's naming convention (PR by Leonardus Chen)
  • Increased mimimum SQLAlchemy version to 1.4.36 to address issues with ForeignKey and indexes, and to eliminate the PostgreSQL UUID column type annotation hack

3.0.0rc1

  • Migrated all packaging/testing configuration to pyproject.toml
  • Fixed unwarranted ForeignKey declarations appearing in column attributes when there are named, single column foreign key constraints (PR by Leonardus Chen)

. Fixed KeyError when rendering an index without any columns - Fixed improper handling of schema prefixes in sequence names in server defaults - Fixed identically named tables from different schemas resulting in invalid generated

code
  • Fixed imports caused by server_default conflicting with class attribute names
  • Worked around PostgreSQL UUID columns getting Any as the type annotation

3.0.0b3

  • Dropped support for Python < 3.7
  • Dropped support for SQLAlchemy 1.3
  • Added a __main__ module which can be used as an alternate entry point to the CLI
  • Added detection for sequence use in column defaults on PostgreSQL
  • Fixed sqlalchemy.exc.InvalidRequestError when encountering a column named "metadata" (regression from 2.0)
  • Fixed missing MetaData import with DeclarativeGenerator when only plain tables are generated
  • Fixed invalid data classes being generated due to some relationships having been rendered without a default value
  • Improved translation of column names into column attributes where the column name has whitespace at the beginning or end
  • Modified constraint and index rendering to add them explicitly instead of using shortcuts like unique=True, index=True or primary=True when the constraint or index has a name that does not match the default naming convention

3.0.0b2

  • Fixed IDENTITY columns not rendering properly when they are part of the primary key

3.0.0b1

NOTE: Both the API and the command line interface have been refactored in a backwards incompatible fashion. Notably several command line options have been moved to specific generators and are no longer visible from sqlacodegen --help. Their replacement are documented in the README.

  • Dropped support for Python < 3.6
  • Added support for Python 3.10
  • Added support for SQLAlchemy 1.4
  • Added support for bidirectional relationships (use --option nobidi) to disable
  • Added support for multiple schemas via --schemas
  • Added support for IDENTITY columns
  • Disabled inflection during table/relationship name generation by default (use --option use_inflect to re-enable)
  • Refactored the old CodeGenerator class into separate generator classes, selectable via --generator
  • Refactored several command line options into generator specific options:
    • --noindexes--option noindexes
    • --noconstraints--option noconstraints
    • --nocomments--option nocomments
    • --nojoined--option nojoined (declarative and dataclass generators only)
    • --noinflect → (now the default; use --option use_inflect instead) (declarative and dataclass generators only)
  • Fixed missing import for JSONB astext_type argument
  • Fixed generated column or relationship names colliding with imports or each other
  • Fixed CompileError when encountering server defaults that contain colons (:)

2.3.0

  • Added support for rendering computed columns
  • Fixed --nocomments not taking effect (fix proposed by AzuresYang)
  • Fixed handling of MySQL SET column types (and possibly others as well)

2.2.0

  • Added support for rendering table comments (PR by David Hirschfeld)
  • Fixed bad identifier names being generated for plain tables (PR by softwarepk)

2.1.0

  • Dropped support for Python 3.4
  • Dropped support for SQLAlchemy 0.8
  • Added support for Python 3.7 and 3.8
  • Added support for SQLAlchemy 1.3
  • Added support for column comments (requires SQLAlchemy 1.2+; based on PR by koalas8)
  • Fixed crash on unknown column types (NullType)

2.0.1

  • Don't adapt dialect specific column types if they need special constructor arguments (thanks Nicholas Martin for the PR)

2.0.0

  • Refactored code for better reuse
  • Dropped support for Python 2.6, 3.2 and 3.3
  • Dropped support for SQLAlchemy < 0.8
  • Worked around a bug regarding Enum on SQLAlchemy 1.2+ (name was missing)
  • Added support for Geoalchemy2
  • Fixed invalid class names being generated (fixes #60; PR by Dan O'Huiginn)
  • Fixed array item types not being adapted or imported (fixes #46; thanks to Martin Glauer and Shawn Koschik for help)
  • Fixed attribute name of columns named metadata in mapped classes (fixes #62)
  • Fixed rendered column types being changed from the original (fixes #11)
  • Fixed server defaults which contain double quotes (fixes #7, #17, #28, #33, #36)
  • Fixed secondary= not taking into account the association table's schema name (fixes #30)
  • Sort models by foreign key dependencies instead of schema and name (fixes #15, #16)

1.1.6

  • Fixed compatibility with SQLAlchemy 1.0
  • Added an option to only generate tables

1.1.5

  • Fixed potential assignment of columns or relationships into invalid attribute names (fixes #10)
  • Fixed unique=True missing from unique Index declarations
  • Fixed several issues with server defaults
  • Fixed potential assignment of columns or relationships into invalid attribute names
  • Allowed pascal case for tables already using it
  • Switched from Mercurial to Git

1.1.4

  • Fixed compatibility with SQLAlchemy 0.9.0

1.1.3

  • Fixed compatibility with SQLAlchemy 0.8.3+
  • Migrated tests from nose to pytest

1.1.2

  • Fixed non-default schema name not being present in __table_args__ (fixes #2)
  • Fixed self referential foreign key causing column type to not be rendered
  • Fixed missing "deferrable" and "initially" keyword arguments in ForeignKey constructs
  • Fixed foreign key and check constraint handling with alternate schemas (fixes #3)

1.1.1

  • Fixed TypeError when inflect could not determine the singular name of a table for a many-to-1 relationship
  • Fixed _IntegerType, _StringType etc. being rendered instead of proper types on MySQL

1.1.0

  • Added automatic detection of joined-table inheritance
  • Fixed missing class name prefix in primary/secondary joins in relationships
  • Instead of wildcard imports, generate explicit imports dynamically (fixes #1)
  • Use the inflect library to produce better guesses for table to class name conversion
  • Automatically detect Boolean columns based on CheckConstraints
  • Skip redundant CheckConstraints for Enum and Boolean columns

1.0.0

  • Initial release