Allow to use Enums in custom DB schema #1146
Open
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
I have a legacy DB which is receiving an API including new tables in a separate DB schema. The new code must not touch the existing objects in the
public
schema.So all models derive from
I have some fields which use Enums:
The DB is PostgreSQL and I'm using the native Enum type (
CREATE TYPE
). Also these types reside in the custom schema.When creating a new
Hero
the generated SQL has explicit casts to the types of the columns. However, for thetype
column only the plain name of the type is generated. Of course that doesn't work, as the Enum type isn't in thepublic
schema.The solution is to pass
inherit_schema=True
when instantiating SQLAlchemy'sEnum
class. I achived this by making a subclass and using that inget_sqlalchemy_type()
instead of the plain one.I'm aware this PR may not be in it's final form. Please advise what needs to be done to get it merged.