mirror of
https://github.com/open-metadata/OpenMetadata.git
synced 2025-07-06 16:47:29 +00:00
330 lines
16 KiB
SQL
330 lines
16 KiB
SQL
-- Add the supportsProfiler field to the MongoDB connection configuration
|
|
UPDATE dbservice_entity
|
|
SET json = JSON_INSERT(json, '$.connection.config.supportsProfiler', TRUE)
|
|
WHERE serviceType = 'MongoDB';
|
|
|
|
-- Queries should be unique:
|
|
-- 1. Remove duplicate queries from entity_relationship
|
|
-- 2. Remove duplicate queries from query_entity
|
|
-- 3. Add checksum with unique constraint
|
|
ALTER TABLE query_entity ADD COLUMN checksum VARCHAR
|
|
(32) GENERATED ALWAYS AS
|
|
(json ->> '$.checksum') NOT NULL;
|
|
|
|
with duplicated as (
|
|
select
|
|
id,
|
|
ROW_NUMBER() OVER (PARTITION BY checksum ORDER BY id) AS rn
|
|
FROM query_entity
|
|
)
|
|
DELETE FROM entity_relationship
|
|
where toEntity = 'query' and toId in (
|
|
select id from duplicated where rn > 1
|
|
);
|
|
|
|
with duplicated as (
|
|
select
|
|
id,
|
|
ROW_NUMBER() OVER (PARTITION BY checksum ORDER BY id) AS rn
|
|
FROM query_entity
|
|
)
|
|
DELETE FROM query_entity where id in (
|
|
select id from duplicated where rn > 1
|
|
);
|
|
|
|
ALTER TABLE query_entity ADD CONSTRAINT unique_query_checksum UNIQUE (checksum);
|
|
|
|
UPDATE query_entity SET json = JSON_INSERT(json, '$.checksum', MD5(JSON_UNQUOTE(checksum)));
|
|
|
|
-- Restructure dbServiceNames in ingestion_pipeline_entity
|
|
update ingestion_pipeline_entity set json =
|
|
JSON_INSERT(
|
|
JSON_REMOVE(json, '$.sourceConfig.config.dbServiceNames'),
|
|
'$.sourceConfig.config.lineageInformation',
|
|
JSON_OBJECT(
|
|
'dbServiceNames',
|
|
JSON_EXTRACT(json, '$.sourceConfig.config.dbServiceNames')
|
|
)
|
|
)
|
|
where
|
|
JSON_EXTRACT(json, '$.sourceConfig.config.type') in ('DashboardMetadata', 'PipelineMetadata')
|
|
AND JSON_EXTRACT(json, '$.sourceConfig.config.dbServiceNames') is not null;
|
|
|
|
|
|
ALTER TABLE chart_entity ADD INDEX index_chart_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE dashboard_data_model_entity ADD INDEX index_dashboard_data_model_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE dashboard_entity ADD INDEX index_dashboard_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE data_insight_chart ADD INDEX index_data_insight_chart_deleted(fqnHash, deleted);
|
|
ALTER TABLE database_entity ADD INDEX index_database_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE database_schema_entity ADD INDEX index_database_schema_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE glossary_term_entity ADD INDEX index_glossary_term_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE ingestion_pipeline_entity ADD INDEX index_ingestion_pipeline_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE metric_entity ADD INDEX index_metric_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE ml_model_entity ADD INDEX index_ml_model_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE pipeline_entity ADD INDEX index_pipeline_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE policy_entity ADD INDEX index_policy_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE report_entity ADD INDEX index_report_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE search_index_entity ADD INDEX index_search_index_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE storage_container_entity ADD INDEX index_storage_container_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE stored_procedure_entity ADD INDEX index_stored_procedure_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE table_entity ADD INDEX index_table_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE tag ADD INDEX index_tag_deleted(fqnHash, deleted);
|
|
ALTER TABLE test_case ADD INDEX index_test_case_deleted(fqnHash, deleted);
|
|
ALTER TABLE test_suite ADD INDEX index_test_suite_deleted(fqnHash, deleted);
|
|
ALTER TABLE topic_entity ADD INDEX index_topic_entity_deleted(fqnHash, deleted);
|
|
ALTER TABLE web_analytic_event ADD INDEX index_web_analytic_event_deleted(fqnHash, deleted);
|
|
|
|
ALTER TABLE apps_marketplace ADD INDEX index_apps_marketplace_deleted(nameHash, deleted);
|
|
ALTER TABLE bot_entity ADD INDEX index_bot_entity_deleted(nameHash, deleted);
|
|
ALTER TABLE classification ADD INDEX index_classification_deleted(nameHash, deleted);
|
|
ALTER TABLE dashboard_service_entity ADD INDEX index_dashboard_service_entity_deleted(nameHash, deleted);
|
|
ALTER TABLE dbservice_entity ADD INDEX index_dbservice_entity_deleted(nameHash, deleted);
|
|
ALTER TABLE glossary_entity ADD INDEX index_glossary_entity_deleted(nameHash, deleted);
|
|
ALTER TABLE installed_apps ADD INDEX index_installed_apps_deleted(nameHash, deleted);
|
|
ALTER TABLE kpi_entity ADD INDEX index_kpi_entity_deleted(nameHash, deleted);
|
|
ALTER TABLE messaging_service_entity ADD INDEX index_messaging_service_entity_deleted(nameHash, deleted);
|
|
ALTER TABLE metadata_service_entity ADD INDEX index_metadata_service_entity_deleted(nameHash, deleted);
|
|
ALTER TABLE mlmodel_service_entity ADD INDEX index_mlmodel_service_entity_deleted(nameHash, deleted);
|
|
ALTER TABLE pipeline_service_entity ADD INDEX index_pipeline_service_entity_deleted(nameHash, deleted);
|
|
ALTER TABLE role_entity ADD INDEX index_role_entity_deleted(nameHash, deleted);
|
|
ALTER TABLE search_service_entity ADD INDEX index_search_service_entity_deleted(nameHash, deleted);
|
|
ALTER TABLE storage_service_entity ADD INDEX index_storage_service_entity_deleted(nameHash, deleted);
|
|
ALTER TABLE team_entity ADD INDEX index_team_entity_deleted(nameHash, deleted);
|
|
ALTER TABLE user_entity ADD INDEX index_user_entity_deleted(nameHash, deleted);
|
|
|
|
ALTER TABLE apps_extension_time_series ADD INDEX apps_extension_time_series_index(appId);
|
|
ALTER TABLE suggestions ADD INDEX index_suggestions_type(suggestionType);
|
|
ALTER TABLE suggestions ADD INDEX index_suggestions_status(status);
|
|
|
|
|
|
-- Add the supportsProfiler field to the DynamoDB connection configuration
|
|
UPDATE dbservice_entity
|
|
SET json = JSON_INSERT(json, '$.connection.config.supportsProfiler', TRUE)
|
|
WHERE serviceType = 'DynamoDB';
|
|
|
|
-- Migrate 'QlikSenseDataModel' & 'QlikCloudDataModel' into single entity 'QlikDataModel'
|
|
UPDATE dashboard_data_model_entity
|
|
SET json = JSON_SET(json, '$.dataModelType', 'QlikDataModel')
|
|
WHERE JSON_EXTRACT(json, '$.dataModelType') in ('QlikSenseDataModel', 'QlikCloudDataModel');
|
|
|
|
-- clean ES pipelines
|
|
DELETE FROM ingestion_pipeline_entity
|
|
WHERE LOWER(JSON_EXTRACT(json, '$.pipelineType')) = 'elasticsearchreindex';
|
|
|
|
|
|
UPDATE dbservice_entity
|
|
SET json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.sslCA'),
|
|
'$.connection.config.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.sslConfig.caCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.sslCA')), json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.sslKey'),
|
|
'$.connection.config.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.sslConfig.sslKey',
|
|
JSON_EXTRACT(json, '$.connection.config.sslKey')), json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.sslCert'),
|
|
'$.connection.config.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.sslConfig.sslCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.sslCert'))
|
|
where serviceType in ('Mysql', 'Doris') AND JSON_EXTRACT(json, '$.connection.config.sslCA') IS NOT NULL;
|
|
|
|
UPDATE dbservice_entity
|
|
SET json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.sslConfig.certificatePath'),
|
|
'$.connection.config.sslConfig.caCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.sslConfig.certificatePath')
|
|
) where serviceType in ('Redshift', 'Postgres', 'Greenplum') and JSON_EXTRACT(json, '$.connection.config.sslConfig.certificatePath') is not null;
|
|
|
|
|
|
UPDATE dbservice_entity
|
|
SET json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.metastoreConnection.sslCA'),
|
|
'$.connection.config.metastoreConnection.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.metastoreConnection.sslConfig.caCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.metastoreConnection.sslCA')), json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.metastoreConnection.sslKey'),
|
|
'$.connection.config.metastoreConnection.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.metastoreConnection.sslConfig.sslKey',
|
|
JSON_EXTRACT(json, '$.connection.config.metastoreConnection.sslKey')), json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.metastoreConnection.sslCert'),
|
|
'$.connection.config.metastoreConnection.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.metastoreConnection.sslConfig.sslCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.metastoreConnection.sslCert'))
|
|
|
|
where serviceType = 'Hive'
|
|
AND JSON_EXTRACT(json, '$.connection.config.metastoreConnection.type') = 'Mysql'
|
|
AND JSON_EXTRACT(json, '$.connection.config.metastoreConnection.sslCA') IS NOT NULL;
|
|
|
|
UPDATE dbservice_entity
|
|
SET json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.metastoreConnection.sslConfig.certificatePath'),
|
|
'$.connection.config.metastoreConnection.sslConfig.caCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.metastoreConnection.sslConfig.certificatePath'))
|
|
where serviceType = 'Hive'
|
|
AND JSON_EXTRACT(json, '$.connection.config.metastoreConnection.type') = 'Postgres'
|
|
AND JSON_EXTRACT(json, '$.connection.config.metastoreConnection.sslConfig.certificatePath') IS NOT NULL;
|
|
|
|
UPDATE dashboard_service_entity
|
|
SET json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.connection.sslCA'),
|
|
'$.connection.config.connection.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.connection.sslConfig.caCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.connection.sslCA')), json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.connection.sslKey'),
|
|
'$.connection.config.connection.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.connection.sslConfig.sslKey',
|
|
JSON_EXTRACT(json, '$.connection.config.connection.sslKey')), json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.connection.sslCert'),
|
|
'$.connection.config.connection.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.connection.sslConfig.sslCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.connection.sslCert'))
|
|
|
|
where serviceType = 'Superset'
|
|
AND JSON_EXTRACT(json, '$.connection.config.connection.type') = 'Mysql'
|
|
AND JSON_EXTRACT(json, '$.connection.config.connection.sslCA') IS NOT NULL;
|
|
|
|
UPDATE dashboard_service_entity
|
|
SET json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.connection.sslConfig.certificatePath'),
|
|
'$.connection.config.connection.sslConfig.caCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.connection.sslConfig.certificatePath'))
|
|
where serviceType = 'Superset'
|
|
AND JSON_EXTRACT(json, '$.connection.config.connection.type') = 'Postgres'
|
|
AND JSON_EXTRACT(json, '$.connection.config.connection.sslConfig.certificatePath') IS NOT NULL;
|
|
|
|
|
|
UPDATE metadata_service_entity
|
|
SET json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.connection.sslCA'),
|
|
'$.connection.config.connection.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.connection.sslConfig.caCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.connection.sslCA')), json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.connection.sslKey'),
|
|
'$.connection.config.connection.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.connection.sslConfig.sslKey',
|
|
JSON_EXTRACT(json, '$.connection.config.connection.sslKey')), json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.connection.sslCert'),
|
|
'$.connection.config.connection.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.connection.sslConfig.sslCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.connection.sslCert'))
|
|
|
|
where serviceType = 'Alation'
|
|
AND JSON_EXTRACT(json, '$.connection.config.connection.type') = 'Mysql'
|
|
AND JSON_EXTRACT(json, '$.connection.config.connection.sslCA') IS NOT NULL;
|
|
|
|
|
|
UPDATE metadata_service_entity
|
|
SET json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.connection.sslConfig.certificatePath'),
|
|
'$.connection.config.connection.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.connection.sslConfig.caCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.connection.sslConfig.certificatePath'))
|
|
where serviceType = 'Alation'
|
|
AND JSON_EXTRACT(json, '$.connection.config.connection.type') = 'Postgres'
|
|
AND JSON_EXTRACT(json, '$.connection.config.connection.sslConfig.certificatePath') IS NOT NULL;
|
|
|
|
|
|
UPDATE dashboard_service_entity
|
|
SET json = JSON_REMOVE(json,'$.connection.config.certificates.stagingDir'), json = JSON_INSERT(JSON_REMOVE(json,'$.connection.config.certificates.rootCertificateData'), '$.connection.config.certificates.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.certificates.sslConfig.caCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.certificates.rootCertificateData')), json = JSON_INSERT(JSON_REMOVE(json,'$.connection.config.certificates.clientCertificateData'), '$.connection.config.certificates.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.certificates.sslConfig.sslCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.certificates.clientCertificateData')),
|
|
json = JSON_INSERT(JSON_REMOVE(json,'$.connection.config.certificates.clientKeyCertificateData'), '$.connection.config.certificates.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.certificates.sslConfig.sslKey',
|
|
JSON_EXTRACT(json, '$.connection.config.certificates.clientKeyCertificateData'))
|
|
|
|
where lower(serviceType) = 'qliksense'
|
|
and JSON_EXTRACT(json, '$.connection.config.certificates.rootCertificateData') is not null;
|
|
|
|
|
|
|
|
UPDATE pipeline_service_entity
|
|
SET json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.connection.sslCA'),
|
|
'$.connection.config.connection.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.connection.sslConfig.caCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.connection.sslCA')), json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.connection.sslKey'),
|
|
'$.connection.config.connection.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.connection.sslConfig.sslKey',
|
|
JSON_EXTRACT(json, '$.connection.config.connection.sslKey')), json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.connection.sslCert'),
|
|
'$.connection.config.connection.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.connection.sslConfig.sslCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.connection.sslCert'))
|
|
|
|
where serviceType = 'Airflow'
|
|
AND JSON_EXTRACT(json, '$.connection.config.connection.type') = 'Mysql'
|
|
AND JSON_EXTRACT(json, '$.connection.config.connection.sslCA') IS NOT NULL;
|
|
|
|
UPDATE pipeline_service_entity
|
|
SET json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.connection.sslConfig.certificatePath'),
|
|
'$.connection.config.connection.sslConfig.caCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.connection.sslConfig.certificatePath'))
|
|
where serviceType = 'Airflow'
|
|
AND JSON_EXTRACT(json, '$.connection.config.connection.type') = 'Postgres'
|
|
AND JSON_EXTRACT(json, '$.connection.config.connection.sslConfig.certificatePath') IS NOT NULL;
|
|
|
|
UPDATE pipeline_service_entity
|
|
SET json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.SSLCALocation'),
|
|
'$.connection.config.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.sslConfig.caCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.SSLCALocation')), json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.SSLKeyLocation'),
|
|
'$.connection.config.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.sslConfig.sslKey',
|
|
JSON_EXTRACT(json, '$.connection.config.SSLKeyLocation')), json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.connection.config.SSLCertificateLocation'),
|
|
'$.connection.config.sslConfig',
|
|
JSON_OBJECT(),
|
|
'$.connection.config.sslConfig.sslCertificate',
|
|
JSON_EXTRACT(json, '$.connection.config.SSLCertificateLocation'))
|
|
|
|
where serviceType = 'OpenLineage'
|
|
AND JSON_EXTRACT(json, '$.connection.config.SSLCALocation') IS NOT NULL;
|
|
|
|
-- Change viewDefinition to schemaDefinition
|
|
UPDATE table_entity
|
|
SET json = JSON_INSERT(
|
|
JSON_REMOVE(json, '$.viewDefinition'),
|
|
'$.schemaDefinition',
|
|
JSON_EXTRACT(json, '$.viewDefinition')
|
|
);
|
|
|
|
UPDATE table_entity SET json = JSON_REMOVE(json, '$.testSuite');
|
|
|
|
-- Clean up QRTZ tables
|
|
delete from QRTZ_SIMPLE_TRIGGERS;
|
|
delete from QRTZ_CRON_TRIGGERS;
|
|
delete from QRTZ_TRIGGERS;
|
|
delete from QRTZ_LOCKS;
|
|
delete from QRTZ_SCHEDULER_STATE;
|
|
delete from QRTZ_JOB_DETAILS;
|
|
delete from QRTZ_FIRED_TRIGGERS;
|
|
|
|
DELETE from event_subscription_entity where name = 'ActivityFeedAlert';
|