data:image/s3,"s3://crabby-images/92566/92566b7878e17fa40acc662e2dd37b069c9d256e" alt=""
Often, there are objects in databases that should not be removed even though they are no longer used. Imagine a store database that includes the following tables:
data:image/s3,"s3://crabby-images/7298f/7298f9961a8148784dbe9a18878a5434cd61c47d" alt="Use a Flag to Mark Active Records"
What happens if the store decides a certain product type is no longer sold? Do you delete it from the database? That is probably not a good idea, as other objects, such as historical orders or invoices, may still be linked to this product type. However, we need a way to differentiate product types that are currently in use from the historical ones.
How to Distinguish Historical Records From the Ones That Are Actively Used
It’s simple – use a Boolean field such as is_active
or is_supported
. You can also create a view that queries the table for active elements only. Whenever the historical data is needed, query the whole table instead. Now, our model looks like this:
data:image/s3,"s3://crabby-images/529fe/529fed36befda29f38d84222ffafe025d9017553" alt="Use a Flag to Mark Active Records"
This solution is often used in dictionary tables, such as product types, tax rates, and inactive tariff plans.