From 29651e8d00f22b9df6965722584a5407cbefe5bc Mon Sep 17 00:00:00 2001 From: cccs-joel Date: Tue, 2 Nov 2021 20:47:39 +0000 Subject: [PATCH 1/5] Change datatype of column type in BaseColumn to allow larger datatype names for complexed columns --- superset/connectors/base/models.py | 2 +- superset/datasets/schemas.py | 2 +- ...5_change_datatype_of_type_in_basecolumn.py | 44 +++++++++++++++++++ 3 files changed, 46 insertions(+), 2 deletions(-) create mode 100644 superset/migrations/versions/3ba29ecbaac5_change_datatype_of_type_in_basecolumn.py diff --git a/superset/connectors/base/models.py b/superset/connectors/base/models.py index 0bd94885a2479..5e92242a84953 100644 --- a/superset/connectors/base/models.py +++ b/superset/connectors/base/models.py @@ -558,7 +558,7 @@ class BaseColumn(AuditMixinNullable, ImportExportMixin): column_name = Column(String(255), nullable=False) verbose_name = Column(String(1024)) is_active = Column(Boolean, default=True) - type = Column(String(32)) + type = Column(Text) groupby = Column(Boolean, default=True) filterable = Column(Boolean, default=True) description = Column(Text) diff --git a/superset/datasets/schemas.py b/superset/datasets/schemas.py index 11f81fd102df7..eadb4e64fc21d 100644 --- a/superset/datasets/schemas.py +++ b/superset/datasets/schemas.py @@ -42,7 +42,7 @@ def validate_python_date_format(value: str) -> None: class DatasetColumnsPutSchema(Schema): id = fields.Integer() column_name = fields.String(required=True, validate=Length(1, 255)) - type = fields.String(validate=Length(1, 32)) + type = fields.String(allow_none=True) verbose_name = fields.String(allow_none=True, Length=(1, 1024)) description = fields.String(allow_none=True) expression = fields.String(allow_none=True) diff --git a/superset/migrations/versions/3ba29ecbaac5_change_datatype_of_type_in_basecolumn.py b/superset/migrations/versions/3ba29ecbaac5_change_datatype_of_type_in_basecolumn.py new file mode 100644 index 0000000000000..e21d73e737328 --- /dev/null +++ b/superset/migrations/versions/3ba29ecbaac5_change_datatype_of_type_in_basecolumn.py @@ -0,0 +1,44 @@ +# Licensed to the Apache Software Foundation (ASF) under one +# or more contributor license agreements. See the NOTICE file +# distributed with this work for additional information +# regarding copyright ownership. The ASF licenses this file +# to you under the Apache License, Version 2.0 (the +# "License"); you may not use this file except in compliance +# with the License. You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, +# software distributed under the License is distributed on an +# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +# KIND, either express or implied. See the License for the +# specific language governing permissions and limitations +# under the License. +"""Change datatype of type in BaseColumn + +Revision ID: 3ba29ecbaac5 +Revises: b92d69a6643c +Create Date: 2021-11-02 17:44:51.792138 + +""" + +# revision identifiers, used by Alembic. +revision = '3ba29ecbaac5' +down_revision = 'b92d69a6643c' + +from alembic import op +import sqlalchemy as sa +from sqlalchemy.dialects import postgresql + +def upgrade(): + + with op.batch_alter_table("table_columns") as batch_op: + batch_op.alter_column( + "type", existing_type=sa.VARCHAR(length=32), type_=sa.TEXT() + ) + +def downgrade(): + with op.batch_alter_table("table_columns") as batch_op: + batch_op.alter_column( + "type", existing_type=sa.TEXT(), type_=sa.VARCHAR(length=32) + ) From 79f2022a96e8c9344c193e9fb797ad9a9f956559 Mon Sep 17 00:00:00 2001 From: cccs-joel Date: Fri, 19 Nov 2021 21:44:57 +0000 Subject: [PATCH 2/5] Fixed formatting --- .../3ba29ecbaac5_change_datatype_of_type_in_basecolumn.py | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/superset/migrations/versions/3ba29ecbaac5_change_datatype_of_type_in_basecolumn.py b/superset/migrations/versions/3ba29ecbaac5_change_datatype_of_type_in_basecolumn.py index e21d73e737328..a16b86949f2a9 100644 --- a/superset/migrations/versions/3ba29ecbaac5_change_datatype_of_type_in_basecolumn.py +++ b/superset/migrations/versions/3ba29ecbaac5_change_datatype_of_type_in_basecolumn.py @@ -23,13 +23,14 @@ """ # revision identifiers, used by Alembic. -revision = '3ba29ecbaac5' -down_revision = 'b92d69a6643c' +revision = "3ba29ecbaac5" +down_revision = "b92d69a6643c" -from alembic import op import sqlalchemy as sa +from alembic import op from sqlalchemy.dialects import postgresql + def upgrade(): with op.batch_alter_table("table_columns") as batch_op: @@ -37,6 +38,7 @@ def upgrade(): "type", existing_type=sa.VARCHAR(length=32), type_=sa.TEXT() ) + def downgrade(): with op.batch_alter_table("table_columns") as batch_op: batch_op.alter_column( From a5a75821bf42d67e593c5707d187707726a9b8e0 Mon Sep 17 00:00:00 2001 From: cccs-joel Date: Mon, 29 Nov 2021 16:50:27 +0000 Subject: [PATCH 3/5] Added an entry in the UPDATING.md file as a potential downtime --- UPDATING.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/UPDATING.md b/UPDATING.md index d844ef4ed01a7..b1a3134e521f3 100644 --- a/UPDATING.md +++ b/UPDATING.md @@ -33,6 +33,8 @@ assists people when migrating to a new version. ### Potential Downtime - [16756](https://github.com/apache/incubator-superset/pull/16756): a change which renames the `dbs.allow_csv_upload` column to `dbs.allow_file_upload` via a (potentially locking) DDL operation. +- [17360](https://github.com/apache/superset/pull/17360): changes the column type from `VARCHAR(32)` to `TEXT` in table `table_columns` could be a table lock on mysql dbs or take some time to complete on large deployments. + ### Deprecations From a12f9880f6e00c963279fc308dce8bef2fbf3135 Mon Sep 17 00:00:00 2001 From: cccs-joel Date: Mon, 13 Dec 2021 13:34:16 -0500 Subject: [PATCH 4/5] Update UPDATING.md Accept proposed changes. Co-authored-by: Beto Dealmeida --- UPDATING.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/UPDATING.md b/UPDATING.md index 938ee4a12a657..1b44f078292d6 100644 --- a/UPDATING.md +++ b/UPDATING.md @@ -38,7 +38,7 @@ assists people when migrating to a new version. - [17539](https://github.com/apache/superset/pull/17539): all Superset CLI commands (init, load_examples and etc) require setting the FLASK_APP environment variable (which is set by default when .flaskenv is loaded) -- [17360](https://github.com/apache/superset/pull/17360): changes the column type from `VARCHAR(32)` to `TEXT` in table `table_columns` could be a table lock on mysql dbs or take some time to complete on large deployments. +- [17360](https://github.com/apache/superset/pull/17360): changes the column type from `VARCHAR(32)` to `TEXT` in table `table_columns`, potentially requiring a table lock on MySQL dbs or taking some time to complete on large deployments. ### Deprecations From bb424505b65e28cbf1c8a4b5a35910adb8f7f522 Mon Sep 17 00:00:00 2001 From: cccs-joel Date: Mon, 13 Dec 2021 19:02:54 +0000 Subject: [PATCH 5/5] Updated down revision number to reflect new head --- .../3ba29ecbaac5_change_datatype_of_type_in_basecolumn.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/superset/migrations/versions/3ba29ecbaac5_change_datatype_of_type_in_basecolumn.py b/superset/migrations/versions/3ba29ecbaac5_change_datatype_of_type_in_basecolumn.py index a16b86949f2a9..15f81488a310c 100644 --- a/superset/migrations/versions/3ba29ecbaac5_change_datatype_of_type_in_basecolumn.py +++ b/superset/migrations/versions/3ba29ecbaac5_change_datatype_of_type_in_basecolumn.py @@ -17,14 +17,14 @@ """Change datatype of type in BaseColumn Revision ID: 3ba29ecbaac5 -Revises: b92d69a6643c +Revises: abe27eaf93db Create Date: 2021-11-02 17:44:51.792138 """ # revision identifiers, used by Alembic. revision = "3ba29ecbaac5" -down_revision = "b92d69a6643c" +down_revision = "abe27eaf93db" import sqlalchemy as sa from alembic import op