Pour faciliter le chargement de données, il est parfois nécessaire de désactiver une contrainte de domaine (CHECK) ou de clé étrangère, puis de la réactiver dès la fin du chargement.
Si l’on écrit :
ALTER TABLE maTable CHECK CONSTRAINT maContrainte
La contrainte est alors marquée comme non-fiable, et le moteur de bases de données ne s’en sert plus dans ses plans de requête.
Pire, cela signifie que l’intégrité des données qui ont été importées est alors mise en défaut.
Il faut donc écrire :
ALTER TABLE maTable WITH CHECK CHECK CONSTRAINT maContrainte
Pour que les valeurs ajoutées pendant que la contrainte était désactivée soient vérifiées.
Voici donc une petite requête pour trouver les contraintes qui ne sont plus fiables pour le moteur de base de données …