Menu

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

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

create rule [MaRule] as @value like '[A-Z][a-z]'
GO
EXEC sp_bindrule N'MaRule', N'[NomTable].[NomColonne]'
GO

Merci sebsauvage 1

Avec quelques mots c'est encore mieux Ajouter un commentaire

CCM a aidé 24469 internautes ce mois-ci

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 33277 Messages postés mercredi 29 août 2001Date d'inscriptionModérateurStatut 26 mars 2015 Dernière intervention - 30 mai 2005 à 10:06
0
Merci
Créé une rule (CREATE RULE...) puis bind là à ta colonne.
(Je n'ai plus la syntaxe en tête).
sebsauvage 33277 Messages postés mercredi 29 août 2001Date d'inscriptionModérateurStatut 26 mars 2015 Dernière intervention - 30 mai 2005 à 10:55
0
Merci
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 33277 Messages postés mercredi 29 août 2001Date d'inscriptionModérateurStatut 26 mars 2015 Dernière intervention - 30 mai 2005 à 10:58
0
Merci
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
Merci
essaye avec ca :
alter table nom_de_table
add constrainte ck_1
check(nom not like '[0-9]')