mirror of
				https://github.com/open-metadata/OpenMetadata.git
				synced 2025-10-22 14:24:35 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			336 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			SQL
		
	
	
	
	
	
			
		
		
	
	
			336 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			SQL
		
	
	
	
	
	
| -- Add a new table di_chart_entity
 | |
| CREATE TABLE IF NOT EXISTS di_chart_entity (
 | |
|     id VARCHAR(36) GENERATED ALWAYS AS (json ->> '$.id') NOT NULL,
 | |
|     name VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.name') NOT NULL,
 | |
|     fullyQualifiedName VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.fullyQualifiedName') NOT NULL,
 | |
|     json JSON NOT NULL,
 | |
|     updatedAt BIGINT UNSIGNED GENERATED ALWAYS AS (json ->> '$.updatedAt') NOT NULL,
 | |
|     updatedBy VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.updatedBy') NOT NULL,
 | |
|     fqnHash varchar(768) CHARACTER SET ascii COLLATE ascii_bin DEFAULT NULL,
 | |
|     deleted BOOLEAN GENERATED ALWAYS AS (json -> '$.deleted'),
 | |
|     UNIQUE(name),
 | |
|     INDEX name_index (name)
 | |
| );
 | |
| 
 | |
| -- Update the KPI entity to remove the targetDefinition and set the targetValue to the value of the targetDefinition
 | |
| UPDATE kpi_entity
 | |
| SET json = JSON_REMOVE(
 | |
|                     JSON_SET(json, 
 | |
|                              '$.targetValue', 
 | |
|                              CAST(JSON_UNQUOTE(JSON_EXTRACT(json, '$.targetDefinition[0].value')) AS DECIMAL) * 100 
 | |
|                             ),
 | |
|                     '$.targetDefinition'
 | |
|                 )
 | |
| WHERE JSON_UNQUOTE(JSON_EXTRACT(json, '$.metricType')) = 'PERCENTAGE';
 | |
| 
 | |
| UPDATE kpi_entity
 | |
| SET json = JSON_REMOVE(
 | |
|                     JSON_SET(json, 
 | |
|                              '$.targetValue', 
 | |
|                              CAST(JSON_UNQUOTE(JSON_EXTRACT(json, '$.targetDefinition[0].value')) AS DECIMAL) 
 | |
|                             ),
 | |
|                     '$.targetDefinition'
 | |
|                 )
 | |
| WHERE JSON_UNQUOTE(JSON_EXTRACT(json, '$.metricType')) = 'NUMBER';
 | |
| -- Update DeltaLake service due to connection schema changes to enable DeltaLake ingestion from Storage
 | |
| UPDATE dbservice_entity dbse
 | |
| SET
 | |
|   dbse.json = JSON_REMOVE(JSON_REMOVE(
 | |
|   JSON_MERGE_PATCH(
 | |
|     dbse.json,
 | |
|     JSON_OBJECT(
 | |
|       'connection', JSON_OBJECT(
 | |
|         'config', JSON_OBJECT(
 | |
|           'configSource', JSON_OBJECT(
 | |
|             'connection', JSON_EXTRACT(dbse.json, '$.connection.config.metastoreConnection'),
 | |
|             'appName', JSON_UNQUOTE(JSON_EXTRACT(dbse.json, '$.connection.config.appName'))
 | |
|           )
 | |
|         )
 | |
|       )
 | |
|     )
 | |
|   )
 | |
|   , '$.connection.config.appName'), '$.connection.config.metastoreConnection')
 | |
| WHERE dbse.serviceType = 'DeltaLake';
 | |
| 
 | |
| -- Allow all bots to update the ingestion pipeline status
 | |
| UPDATE policy_entity
 | |
| SET json = JSON_ARRAY_APPEND(
 | |
|     json,
 | |
|     '$.rules',
 | |
|     CAST('{
 | |
|       "name": "BotRule-IngestionPipeline",
 | |
|       "description": "A bot can Edit ingestion pipelines to pass the status",
 | |
|       "resources": ["ingestionPipeline"],
 | |
|       "operations": ["ViewAll","EditIngestionPipelineStatus"],
 | |
|       "effect": "allow"
 | |
|     }' AS JSON)
 | |
|   )
 | |
| WHERE name = 'DefaultBotPolicy';
 | |
| 
 | |
| -- create API service entity
 | |
| CREATE TABLE IF NOT EXISTS api_service_entity (
 | |
|     id VARCHAR(36) GENERATED ALWAYS AS (json ->> '$.id') STORED NOT NULL,
 | |
|     nameHash VARCHAR(256)  NOT NULL COLLATE ascii_bin,
 | |
|     name VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.name') NOT NULL,
 | |
|     serviceType VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.serviceType') NOT NULL,
 | |
|     json JSON NOT NULL,
 | |
|     updatedAt BIGINT UNSIGNED GENERATED ALWAYS AS (json ->> '$.updatedAt') NOT NULL,
 | |
|     updatedBy VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.updatedBy') NOT NULL,
 | |
|     deleted BOOLEAN GENERATED ALWAYS AS (json -> '$.deleted'),
 | |
|     PRIMARY KEY (id),
 | |
|     UNIQUE (nameHash),
 | |
|     INDEX (name)
 | |
| );
 | |
| 
 | |
| -- create API collection entity
 | |
| CREATE TABLE IF NOT EXISTS api_collection_entity (
 | |
|     id VARCHAR(36) GENERATED ALWAYS AS (json ->> '$.id') STORED NOT NULL,
 | |
|     name VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.name') NOT NULL,
 | |
|     fqnHash VARCHAR(256) NOT NULL COLLATE ascii_bin,
 | |
|     json JSON NOT NULL,
 | |
|     updatedAt BIGINT UNSIGNED GENERATED ALWAYS AS (json ->> '$.updatedAt') NOT NULL,
 | |
|     updatedBy VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.updatedBy') NOT NULL,
 | |
|     deleted BOOLEAN GENERATED ALWAYS AS (json -> '$.deleted'),
 | |
|     PRIMARY KEY (id),
 | |
|     UNIQUE (fqnHash),
 | |
|     INDEX (name)
 | |
| );
 | |
| 
 | |
| -- create API Endpoint entity
 | |
| CREATE TABLE IF NOT EXISTS api_endpoint_entity (
 | |
|     id VARCHAR(36) GENERATED ALWAYS AS (json ->> '$.id') STORED NOT NULL,
 | |
|     name VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.name') NOT NULL,
 | |
|     fqnHash VARCHAR(256) NOT NULL COLLATE ascii_bin,
 | |
|     json JSON NOT NULL,
 | |
|     updatedAt BIGINT UNSIGNED GENERATED ALWAYS AS (json ->> '$.updatedAt') NOT NULL,
 | |
|     updatedBy VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.updatedBy') NOT NULL,
 | |
|     deleted BOOLEAN GENERATED ALWAYS AS (json -> '$.deleted'),
 | |
|     PRIMARY KEY (id),
 | |
|     UNIQUE (fqnHash),
 | |
|     INDEX (name)
 | |
| );
 | |
| 
 | |
| -- Clean dangling workflows not removed after test connection
 | |
| truncate automations_workflow;
 | |
| 
 | |
| -- Remove date, dateTime, time from type_entity, as they are no more om-field-types, instead we have date-cp, time-cp, dateTime-cp as om-field-types
 | |
| DELETE FROM type_entity
 | |
| WHERE name IN ('date', 'dateTime', 'time');
 | |
| 
 | |
| -- Update BigQuery,Bigtable & Datalake model for gcpCredentials to move `gcpConfig` value to `gcpConfig.path`
 | |
| UPDATE dbservice_entity
 | |
| SET json = JSON_INSERT(
 | |
|     JSON_REMOVE(json, '$.connection.config.credentials.gcpConfig'),
 | |
|     '$.connection.config.credentials.gcpConfig',
 | |
|     JSON_OBJECT(),
 | |
|     '$.connection.config.credentials.gcpConfig.path',
 | |
|     JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig')
 | |
| ) where serviceType in ('BigQuery', 'BigTable') and 
 | |
| (JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig.type') OR 
 | |
| JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig.externalType') OR 
 | |
| JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig.path')) is NULL;
 | |
| 
 | |
| UPDATE dbservice_entity
 | |
| SET json = JSON_INSERT(
 | |
|     JSON_REMOVE(json, '$.connection.config.configSource.securityConfig.gcpConfig'),
 | |
|     '$.connection.config.configSource.securityConfig.gcpConfig',
 | |
|     JSON_OBJECT(),
 | |
|     '$.connection.config.configSource.securityConfig.gcpConfig.path',
 | |
|     JSON_EXTRACT(json, '$.connection.config.configSource.securityConfig.gcpConfig')
 | |
| ) where serviceType in ('Datalake') and 
 | |
| (JSON_EXTRACT(json, '$.connection.config.configSource.securityConfig.gcpConfig.type') OR 
 | |
| JSON_EXTRACT(json, '$.connection.config.configSource.securityConfig.gcpConfig.externalType') OR 
 | |
| JSON_EXTRACT(json, '$.connection.config.configSource.securityConfig.gcpConfig.path')) is NULL and 
 | |
| JSON_EXTRACT(json, '$.connection.config.configSource.securityConfig.gcpConfig') is NOT NULL;
 | |
| 
 | |
| -- Update Powerbi model for pbitFilesSource to move `gcpConfig` value to `gcpConfig.path`
 | |
| UPDATE dashboard_service_entity 
 | |
| SET json = JSON_INSERT(
 | |
|     JSON_REMOVE(json, '$.connection.config.pbitFilesSource.securityConfig.gcpConfig'),
 | |
|     '$.connection.config.pbitFilesSource.securityConfig.gcpConfig',
 | |
|     JSON_OBJECT(),
 | |
|     '$.connection.config.pbitFilesSource.securityConfig.gcpConfig.path',
 | |
|     JSON_EXTRACT(json, '$.connection.config.pbitFilesSource.securityConfig.gcpConfig')
 | |
| ) where serviceType in ('PowerBI') and 
 | |
| (JSON_EXTRACT(json, '$.connection.config.pbitFilesSource.securityConfig.gcpConfig.type') OR 
 | |
| JSON_EXTRACT(json, '$.connection.config.pbitFilesSource.securityConfig.gcpConfig.externalType') OR 
 | |
| JSON_EXTRACT(json, '$.connection.config.pbitFilesSource.securityConfig.gcpConfig.path')) is NULL AND 
 | |
| JSON_EXTRACT(json, '$.connection.config.pbitFilesSource.securityConfig.gcpConfig') is not null;
 | |
| 
 | |
| UPDATE storage_service_entity
 | |
| SET json = JSON_INSERT(
 | |
|     JSON_REMOVE(json, '$.connection.config.credentials.gcpConfig'),
 | |
|     '$.connection.config.credentials.gcpConfig',
 | |
|     JSON_OBJECT(),
 | |
|     '$.connection.config.credentials.gcpConfig.path',
 | |
|     JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig')
 | |
| ) where serviceType in ('GCS') and 
 | |
| (JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig.type') OR 
 | |
| JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig.externalType') OR 
 | |
| JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig.path')) is NULL;
 | |
| 
 | |
| UPDATE ingestion_pipeline_entity
 | |
| SET json = JSON_INSERT(
 | |
|     JSON_REMOVE(json, '$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig'),
 | |
|     '$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig',
 | |
|     JSON_OBJECT(),
 | |
|     '$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig.path',
 | |
|     JSON_EXTRACT(json, '$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig')
 | |
| ) where JSON_EXTRACT(json, '$.sourceConfig.config.type') = 'DBT' and (
 | |
| JSON_EXTRACT(json, '$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig.type') OR 
 | |
| JSON_EXTRACT(json, '$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig.externalType') OR 
 | |
| JSON_EXTRACT(json, '$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig.path')
 | |
| ) is NULL AND JSON_EXTRACT(json, '$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig') is not null;
 | |
| 
 | |
| -- Update Owner Field to Owners
 | |
| DELETE from event_subscription_entity where name = 'ActivityFeedAlert';
 | |
| 
 | |
| -- Update thread_entity to move previousOwner and updatedOwner to array
 | |
| UPDATE thread_entity
 | |
| SET json = JSON_SET(
 | |
|     json,
 | |
|     '$.feedInfo.entitySpecificInfo.previousOwner',
 | |
|     JSON_ARRAY(
 | |
|         JSON_EXTRACT(json, '$.feedInfo.entitySpecificInfo.previousOwner')
 | |
|     )
 | |
| )
 | |
| WHERE JSON_CONTAINS_PATH(json, 'one', '$.feedInfo.entitySpecificInfo.previousOwner')
 | |
| AND JSON_TYPE(JSON_EXTRACT(json, '$.feedInfo.entitySpecificInfo.previousOwner')) <> 'ARRAY';
 | |
| 
 | |
| UPDATE thread_entity
 | |
| SET json = JSON_SET(
 | |
|     json,
 | |
|     '$.feedInfo.entitySpecificInfo.updatedOwner',
 | |
|     JSON_ARRAY(
 | |
|         JSON_EXTRACT(json, '$.feedInfo.entitySpecificInfo.updatedOwner')
 | |
|     )
 | |
| )
 | |
| WHERE JSON_CONTAINS_PATH(json, 'one', '$.feedInfo.entitySpecificInfo.updatedOwner')
 | |
| AND JSON_TYPE(JSON_EXTRACT(json, '$.feedInfo.entitySpecificInfo.updatedOwner')) <> 'ARRAY';
 | |
| 
 | |
| -- Update entity_extension to move owner to array
 | |
| update entity_extension set json = JSON_SET(
 | |
|     JSON_REMOVE(json, '$.owner'),
 | |
|     '$.owners',
 | |
|     JSON_ARRAY(
 | |
|         JSON_EXTRACT(json, '$.owner')
 | |
|     )
 | |
| ) where json -> '$.owner' is not null;
 | |
| 
 | |
| ALTER TABLE test_case MODIFY COLUMN `name` VARCHAR(512) GENERATED ALWAYS AS (json ->> '$.name') NOT NULL;
 | |
| 
 | |
| -- set templates to fetch emailTemplates
 | |
| UPDATE openmetadata_settings
 | |
| SET json = JSON_SET(json, '$.templates', 'openmetadata')
 | |
| WHERE configType = 'emailConfiguration';
 | |
| 
 | |
| -- remove dangling owner and service from ingestion pipelines. This info is in entity_relationship
 | |
| UPDATE ingestion_pipeline_entity
 | |
| SET json = JSON_REMOVE(json, '$.owner', '$.service');
 | |
| 
 | |
| ALTER TABLE thread_entity ADD COLUMN domain VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.domain');
 | |
| 
 | |
| -- Remove owner from json from all entities
 | |
| update api_collection_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update api_endpoint_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update api_service_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update bot_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update chart_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update dashboard_data_model_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update dashboard_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update dashboard_service_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update data_product_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update database_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update database_schema_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update dbservice_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update di_chart_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update domain_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update event_subscription_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update glossary_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update glossary_term_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update ingestion_pipeline_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update kpi_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update messaging_service_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update metadata_service_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update metric_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update ml_model_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update mlmodel_service_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update persona_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update pipeline_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update pipeline_service_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update policy_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update query_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update report_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update role_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update search_index_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update search_service_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update storage_container_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update storage_service_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update stored_procedure_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update table_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update team_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update thread_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update topic_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update type_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update user_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update test_case set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update installed_apps set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update apps_marketplace set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update classification set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update storage_container_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update data_insight_chart set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update doc_store set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update tag set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update test_connection_definition set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update test_definition set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update test_suite set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update topic_entity set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update web_analytic_event set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| update automations_workflow set json = JSON_REMOVE(json, '$.owner') where json -> '$.owner' is not null;
 | |
| 
 | |
| update table_entity set json = JSON_SET(
 | |
|     JSON_REMOVE(json, '$.dataModel.owner'),
 | |
|     '$.dataModel.owners',
 | |
|     JSON_ARRAY(
 | |
|         JSON_EXTRACT(json, '$.dataModel.owner')
 | |
|     )
 | |
| ) where json -> '$.dataModel.owner' is not null;
 | |
| 
 | |
| 
 | |
| ALTER TABLE automations_workflow DROP COLUMN status, DROP COLUMN workflowType;
 | |
| ALTER TABLE automations_workflow
 | |
|   ADD COLUMN status VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.status') STORED,
 | |
|   ADD COLUMN workflowType VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.workflowType') STORED NOT NULL;
 | |
| 
 | |
| ALTER TABLE entity_extension ADD INDEX extension_index(extension);
 | |
| 
 | |
| ALTER TABLE test_definition MODIFY COLUMN `name` VARCHAR(512) GENERATED ALWAYS AS (json ->> '$.name') NOT NULL;
 | |
| 
 | |
| -- Remove SearchIndexing for api Service, collection and endpoint
 | |
| DELETE er FROM entity_relationship er JOIN installed_apps ia ON er.fromId = ia.id OR er.toId = ia.id WHERE ia.name = 'SearchIndexingApplication';
 | |
| DELETE er FROM entity_relationship er JOIN apps_marketplace ia ON er.fromId = ia.id OR er.toId = ia.id WHERE ia.name = 'SearchIndexingApplication';
 | |
| DELETE from installed_apps where name = 'SearchIndexingApplication';
 | |
| DELETE from apps_marketplace where name = 'SearchIndexingApplication';
 | |
| 
 | |
| -- Drop the existing taskAssigneesIds
 | |
| DROP INDEX taskAssigneesIds_index ON thread_entity;
 | |
| 
 | |
| ALTER TABLE thread_entity DROP COLUMN taskAssigneesIds;
 | |
| 
 | |
| ALTER TABLE thread_entity
 | |
| ADD COLUMN taskAssigneesIds TEXT GENERATED ALWAYS AS (
 | |
|     REPLACE(
 | |
|         REPLACE(
 | |
|             JSON_UNQUOTE(
 | |
|                 JSON_EXTRACT(taskAssignees, '$[*].id')
 | |
|             ), '[', ''
 | |
|         ), ']', ''
 | |
|     )
 | |
| ) STORED;
 | |
| 
 | |
| CREATE FULLTEXT INDEX taskAssigneesIds_index ON thread_entity(taskAssigneesIds);
 | |
| 
 | |
| -- Add indexes on thread_entity and entity_relationship to improve count/feed api performance
 | |
| CREATE INDEX idx_thread_entity_entityId_createdAt ON thread_entity (entityId, createdAt);
 | |
| CREATE INDEX idx_thread_entity_id_type_status ON thread_entity (id, type, taskStatus);
 | |
| CREATE INDEX idx_er_fromEntity_fromId_toEntity_relation ON entity_relationship (fromEntity, fromId, toEntity, relation); | 
