Contraintes d'intégrité
Hermes-server peut gérer plusieurs types de données, avec des liens (clés étrangères) entre eux, et peut leur appliquer des contraintes d’intégrité.
Illustrons cela avec un cas d’utilisation typique d’utilisateurs / groupes / membres de groupes.
classDiagram
direction BT
GroupsMembers <-- Users
GroupsMembers <-- Groups
class Users{
user_id
...
}
class Groups{
group_id
...
}
class GroupsMembers{
user_id
group_id
integrity() _SELF.user_id in Users_pkeys and _SELF.group_id in Groups_pkeys
}
Dans ce scénario, les entrées dans GroupsMembers qui ont un user_id qui n’existe pas dans Users, ou un group_id qui n’existe pas dans Groups seront ignorées silencieusement.
Pour plus de détails, veuillez consulter integrity_constraints dans la configuration d’hermes-server.