- AS ODC doesn't have product deletion feature with an intention to keep an immutable history of datasets, following scripts are created to manually delete an entire ODC Product and related records in ODC, Explorer and OWS DB.
delete_odc_product_ows.sql
delete_odc_product.sql
delete_odc_product_explorer.sql
cleanup_explorer.sql
- These scripts deletes data, so review the scripts thoroughly and use it very carefully!
- Use with PSQL from the command line. Each script takes <product_name> and DB credentials as an input parameter.
psql -v product_name=<product-to-delete> -f <scriptname.sql> -h <database-hostname> <dbname>
- Before deleting product from ODC DB, we need check if the product has been added to OWS.
- If the product has been added to OWS, some of these tables have a foreign key constraint with ODC table, which will prevent rows being deleted from the main ODC database.
- Table
agdc.dataset_type
has foreign key constraintwms.product_ranges_id_fkey
on tablewms.product_ranges
- Because of the foreign key constraint, deleting datasets for a product in the ODC DB will fail and raise following error:
- ERROR: update or DELETE on table "dataset_type" violates foreign key constraint "product_ranges_id_fkey" on table "product_ranges"
- DETAIL: Key (id)=(1) is still referenced from table "product_ranges".
- To avoid this, there is a need to run
delete_odc_product_ows.sql
script before runningdelete_odc_product.sql
. - This script will delete records from tables
wms.product_ranges
andwms.sub_product_ranges
.
- Before deletion of an product in ODC DB, Explorer's Schema needs to be cleaned as this script makes reference to ODC DB.
- This script will delete records related to an ODC product from the Explorer Schema in the ODC DB.
- It unnests the product id
derived_product_refs
andsource_product_refs
columns fromcubedash.product
table - It deletes records from these tables
cubedash.region
,cubedash.time_overview
,cubedash.product
.
- This script will delete a product and all datasets from an ODC DB.
- It will delete lineage records from the table
agdc.dataset_source
. - It will delete location records from the table
agdc.dataset_location
. - It deletes dataset records from the table
agdc.dataset
. - It deletes the product from the table
agdc.dataset_type
. - It also deletes indexes and view created for that ODC product.
Note: The delete_odc_product.sql
is sourced from here and additional script to delete index and view are added.
- It deletes records from these tables
cubedash.dataset_spatial
for all dataset_type deleted from ODC DB - Then it refreshes materialised view
cubedash.mv_dataset_spatial_quality
as this materialized view directly derives offcubedash.dataset_spatial
- First, run
delete_odc_product_ows.sql
(optional: this step is not required if the product has not been added to OWS).
psql -v product_name=<product-to-delete> -f delete_odc_product_ows.sql -h <database-hostname> <dbname>
- Next run
delete_odc_product_explorer.sql
to delete products from Explorer DB.
psql -v product_name=<product-to-delete> -f delete_odc_product_explorer.sql -h <database-hostname> <dbname>
- Finally run
delete_odc_product.sql
to delete the ODC product in ODC DB.
psql -v product_name=<product-to-delete> -f delete_odc_product.sql -h <database-hostname> <dbname>
- Run
cleanup_explorer.sql
to refresh materialized view for deleted product.
psql -f cleanup_explorer.sql -h <database-hostname> <dbname>
- setup env
export DB_PORT=5432
export DB_DATABASE=dbname
export DB_HOSTNAME=localhost
- First, run
delete_odc_product_ows.sql
(optional: this step is not required if the product has not been added to OWS).
export DB_USERNAME=ows_admin
export DB_PASSWORD=<ows_admin_password>
PGPASSWORD=$DB_PASSWORD psql -v product_name=<product-to-delete> -f delete_odc_product_ows.sql -h $DB_HOSTNAME $DB_DATABASE -U $DB_USERNAME -p $DB_PORT
- Next run
delete_odc_product_explorer.sql
to delete products from Explorer DB.
export DB_USERNAME=explorer_admin
export DB_PASSWORD=<explorer_admin_password>
PGPASSWORD=$DB_PASSWORD psql -v product_name=<product-to-delete> -f delete_odc_product_explorer.sql -h $DB_HOSTNAME $DB_DATABASE -U $DB_USERNAME -p $DB_PORT
- Finally run
delete_odc_product.sql
to delete the ODC product in ODC DB.
export DB_USERNAME=odc_admin
export DB_PASSWORD=<odc_admin_password>
PGPASSWORD=$DB_PASSWORD psql -v product_name=<product-to-delete> -f delete_odc_product.sql -h $DB_HOSTNAME $DB_DATABASE -U $DB_USERNAME -p $DB_PORT
- Next run
cleanup_explorer.sql
to delete products from Explorer DB.
export DB_USERNAME=explorer_admin
export DB_PASSWORD=<explorer_admin_password>
PGPASSWORD=$DB_PASSWORD psql -f cleanup_explorer.sql -h $DB_HOSTNAME $DB_DATABASE -U $DB_USERNAME -p $DB_PORT