Quantcast
Channel: Le Blog SQL Server d'ElSüket » elsuket
Viewing all articles
Browse latest Browse all 197

Trouver les contraintes qui ne sont pas fiables

$
0
0

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 …

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
-------------------------------
-- Nicolas SOUQUET - 26/03/2010
-------------------------------
SELECT    name AS constraint_name
    , CASE KO
      WHEN 0 THEN 1
      WHEN 1 THEN 0
    END AS OK
FROM
(
  SELECT    O.name
      , CASE O.type_desc
        WHEN 'CHECK_CONSTRAINT' THEN CHK.is_not_trusted
        WHEN 'FOREIGN_KEY_CONSTRAINT' THEN FK.is_not_trusted
      END AS KO
  FROM    sys.objects AS O
  LEFT JOIN  sys.check_constraints AS CHK
        ON CHK.object_id = O.object_id
  LEFT JOIN  sys.foreign_keys AS FK
        ON FK.object_id = O.object_id
  WHERE
  (
      CHK.object_id IS NOT NULL
      OR FK.object_id IS NOT NULL
  )
)
AS SUB (name, KO)

Et une autre pour scripter leur réactivation :

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
-------------------------------
-- Nicolas SOUQUET - 26/03/2009
-------------------------------
SELECT    'ALTER TABLE ' + T.name + ' WITH CHECK CHECK CONSTRAINT ' + O.name AS script
FROM    sys.objects AS O
LEFT JOIN  sys.check_constraints AS CHK
      ON CHK.object_id = O.object_id
LEFT JOIN  sys.foreign_keys AS FK
      ON FK.object_id = O.object_id
LEFT JOIN  sys.tables AS T
      ON O.parent_object_id = T.object_id
WHERE
(
  CHK.is_not_trusted = 1
  OR FK.is_not_trusted = 1
)

Bonne vérification d’intégrité !

ElSüket.


Viewing all articles
Browse latest Browse all 197

Trending Articles