It can be useful to tag your records with a unique identifier that doesn't change. Some advanced implementors have realized that the database which underlies App Builder gives its records an ID, and have leveraged this ID for those purposes. ( {{ atom.id }}
can be retrieved by Liquid.)
Unfortunately, the database ID is not intended for this purpose, and it is not safe to use it in this way. Why not? Because the database ID isn't necessarily stable. Right now many corporations are being moved from the Mongo database to Postgres, and this causes the atom ID's to change. And who knows what other refinements may arise in the future? The development team can't guarantee that using the database ID is a safe thing to do.
Does this mean that the ID is useless? No — it just means you have to be a bit smarter about it. The best practice is to use the database ID to set a field on the record: on atom creation, use a Transaction Created business rule to fire an Update Transaction action which stores {{ atom.id }}
in the field. (Naturally this field should have hidden condition of true
, and probably should be set not to show on the dashboard grid either.)
Once you've done that, you then just don't ever do anything else to that field, and it becomes an unchanging identifier. As a bonus, it also becomes accessible to Raw Transaction Filters.