-
-
Notifications
You must be signed in to change notification settings - Fork 254
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Alembic generates unneeded migrations for expression-based indexes #1321
Comments
These issues might be impossible to fix without dropping the support for expression-based indexes, since we can never match 100% of PG expressions to what a particular expression sends. your text() work around is the correct approach. @CaselIT can you suggest other ways to handle this? It seems like we are never going to be able to match these index expressions in all cases. |
I would need to look into what pg returns here. I'll try taking a look once I have a solution for the pc :/ |
I ran into a similar issue with this index definition (I think it is not an expression-based index): Index("ix__meme_asset__latest_sale_date__nulls_first", latest_sale_date.asc().nullsfirst()) The index was already created in the database, however after migrating to sqlalchemy2, alembic started to generate drop and create commands for this index. The generated commands are below. Note the difference in the def upgrade():
# ### commands auto generated by Alembic - please adjust! ###
op.drop_index('ix__meme_asset__latest_sale_date__nulls_first', table_name='meme_asset')
op.create_index('ix__meme_asset__latest_sale_date__nulls_first', 'meme_asset', [sa.text('latest_sale_date ASC NULLS FIRST')], unique=False)
# ### end Alembic commands ###
def downgrade():
# ### commands auto generated by Alembic - please adjust! ###
op.drop_index('ix__meme_asset__latest_sale_date__nulls_first', table_name='meme_asset')
op.create_index('ix__meme_asset__latest_sale_date__nulls_first', 'meme_asset', [sa.text('latest_sale_date NULLS FIRST')], unique=False)
# ### end Alembic commands ### When I change the index definition in a way that the index is still the same (see below), the drop and create index commands are not being generated anymore (the difference from the first definition is that here we are not using Index("ix__meme_asset__latest_sale_date__nulls_first", latest_sale_date.nullsfirst()) |
thanks for reporting. I guess ASC can be removed from the comparison, but in general similar things are likely to happen. @zzzeek do you think it warrants an option in the config to list a collection of index names for which to ignore the expression comparison? This feature has been out for quite a bit and we haven't had much complains on it, so I don't disabling it entirely would be a good option for the majority of users |
we arleady have a feature to ignore a specific list of index names, the include_object hook. |
yes, but that will ignore the index completely, what I was thinking about was just a way of telling alembic "ignore expression difference in this index, but otherwise write migration if it gets removed or the columns change" type of thing |
seems very arbitrary and specific. what if they have a server default that's not comparing correctly, showing false positives? |
also, if I go through the effort to name a specific index to ignore, I would think I'd just have that index ignored and that would be that, I wouldn't want to get into "only compare the columns" - the use case here is that of locating elements that have changed in the codebase as a convenience feature. |
unfortunately what we likely need here is a full fledged tokenizer for PG style constraints, that tokenizes out casts, parenthesis, the whole thing, and compares intent |
let's try for now to solve this by improving the case of json indexes, ignoring asc and improving logging. if we keep getting other complains then we can figure out the next steps |
Federico Caselli has proposed a fix for this issue in the main branch: More PostgreSQL expression index compare fixes https://gerrit.sqlalchemy.org/c/sqlalchemy/alembic/+/4912 |
Describe the bug
I have a table that has an index like this:
In database it is represented as follows:
After migrating to SQLAlchemy 2.0 Alembic started to generate migrations that drop the index, and create another, that is the same, but uses another syntax:
After upgrade, the index is the same as before:
Expected behavior
No migrations are created for the index.
To Reproduce
Please try to provide a Minimal, Complete, and Verifiable example, with the migration script and/or the SQLAlchemy tables or models involved.
See also Reporting Bugs on the website.
Versions.
Additional context
Currently, I solved this by using a
text()
notation for the index expression:This doesn't cause any new migrations.
Have a nice day!
The text was updated successfully, but these errors were encountered: