Sous-requêtes dans les contraintes de vérification : exploration de solutions alternatives
Les contraintes de vérification renforcent l'intégrité des données en limitant les valeurs qui peuvent être insérées ou mises à jour dans une colonne . Bien que les sous-requêtes offrent un moyen puissant de spécifier des conditions complexes, elles ne sont généralement pas autorisées dans les contraintes de vérification dans SQL Server. Cette limitation nous confronte au défi de faire respecter l'intégrité des données par rapport à d'autres tables.
Une solution consiste à utiliser des déclencheurs. Cependant, les déclencheurs peuvent introduire des implications supplémentaires en matière de surcharge et de performances. Comme alternative, nous pouvons utiliser des fonctions scalaires pour encapsuler des sous-requêtes et renvoyer une valeur booléenne qui peut être utilisée dans les contraintes de vérification.
Pour illustrer cette approche, considérons une contrainte de vérification qui vérifie si une valeur dans une colonne (MyField ) existe dans une autre table (Tableau2). Voici comment créer une fonction pour effectuer cette vérification :
CREATE FUNCTION myFunction(@Field DATATYPE(?)) RETURNS VARCHAR(5) AS BEGIN IF EXISTS (SELECT * FROM Table2 WHERE MYFIELD = @field) return 'True' return 'False' END
Cette fonction accepte un paramètre, vérifie son existence dans le tableau 2 et renvoie une valeur booléenne. Nous pouvons ensuite incorporer cette fonction dans notre contrainte de vérification :
ALTER TABLE Table1 WITH CHECK ADD CONSTRAINT CK_Code CHECK (myFunction(MYFIELD) = 'True')
En utilisant une fonction scalaire, nous pouvons effectuer efficacement la validation de sous-requête souhaitée dans la contrainte de vérification, garantissant ainsi l'intégrité des données sans compromettre les performances ni recourir à des déclencheurs.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!