Contraintes check +SQLServer [Fermé]

gauchino 12 Messages postés mardi 16 novembre 2004Date d'inscription 30 mai 2005 Dernière intervention - 30 mai 2005 à 09:52 - Dernière réponse :  yazane
- 1 juin 2007 à 16:22
bonjour
je voudrais une écrire une contrainte sur un champ de type varchar dans une BD SQLServer, le champ s'appelle nom je voudrais m'assurer qu'il ne comporte pas de chiffre(A-Z)
j'ai écrit:
alter table matable
add constrainte nom_valide
check(nom like('[A-Z][a-z]'))

mais SQLServer ne l'accepte pas, si vous pouvez m'aider
N.b : j'ai bien vérifier que les données existantes vérifient la contrainte
merci d'avance
Afficher la suite 

8 réponses

sebsauvage 33278 Messages postés mercredi 29 août 2001Date d'inscriptionModérateurStatut 26 mars 2015 Dernière intervention - 30 mai 2005 à 10:10
+1
Utile
1
La syntaxe:

create rule [MaRule] as @value like '[A-Z][a-z]'
GO
EXEC sp_bindrule N'MaRule', N'[NomTable].[NomColonne]'
GO
Cette réponse vous a-t-elle aidé ?  
gauchino 12 Messages postés mardi 16 novembre 2004Date d'inscription 30 mai 2005 Dernière intervention - 30 mai 2005 à 10:31
j'ai créer la régle, mais en inserant des données ,il n'accepte que les données de 2 lettres en majiscule ou miniscule( exemple FR ou fr) mais si je lui insére un nom de plus que 2 lettres il me génére un conflit à cause de la règle.
sebsauvage 33278 Messages postés mercredi 29 août 2001Date d'inscriptionModérateurStatut 26 mars 2015 Dernière intervention - 30 mai 2005 à 10:06
0
Utile
Créé une rule (CREATE RULE...) puis bind là à ta colonne.
(Je n'ai plus la syntaxe en tête).
sebsauvage 33278 Messages postés mercredi 29 août 2001Date d'inscriptionModérateurStatut 26 mars 2015 Dernière intervention - 30 mai 2005 à 10:55
0
Utile
1
ah oui pardon.
Effectivement cette expression ne match pas plusieurs caractères.
gauchino 12 Messages postés mardi 16 novembre 2004Date d'inscription 30 mai 2005 Dernière intervention - 30 mai 2005 à 11:03
et vous ne savez pas comment on fait pour tout l'alphabet
sebsauvage 33278 Messages postés mercredi 29 août 2001Date d'inscriptionModérateurStatut 26 mars 2015 Dernière intervention - 30 mai 2005 à 10:58
0
Utile
1
La syntaxe d'expression régulières de SQL Server est très limitée.
Je doute que tu arrive à ajouter une telle contrainte.

Il faudra implémenter cette contrainte au niveau de ton code, je le crains.
gauchino 12 Messages postés mardi 16 novembre 2004Date d'inscription 30 mai 2005 Dernière intervention - 30 mai 2005 à 11:42
merci en tout cas
0
Utile
essaye avec ca :
alter table nom_de_table
add constrainte ck_1
check(nom not like '[0-9]')