Concatenation et clé primaire
Résolu
castours
Messages postés
2955
Date d'inscription
Statut
Membre
Dernière intervention
-
castours Messages postés 2955 Date d'inscription Statut Membre Dernière intervention -
castours Messages postés 2955 Date d'inscription Statut Membre Dernière intervention -
A voir également:
- Clé primaire concaténée
- Clé usb non détectée - Guide
- Clé windows 8 - Guide
- Formater clé usb - Guide
- Clé usb - Accueil - Stockage
- Clé bootable windows 10 - Guide
11 réponses
Bonjour,
lorsque vous avez construit votre clé primaire, votre table contenait déjà des données je parie non ? Car dans ce cas vous avez raison (sauf sur le Null)
Pour que cela fonctionne,il faut au départ que la table soit vide.
Créer une table, avec un champ "ID", vous ne choisissez pas "Numéro auto" mais une valeur numérique ou de type texte et vous définissez ce champ comme étant la clé primaire.
Remplissez la table et vous verrez que cela fonctionne très bien.
Si vous ne pouvez pas partir d'une table vide, il suffit de définir votre champ comme "unique", cela aura le même effet que la clé primaire.
lorsque vous avez construit votre clé primaire, votre table contenait déjà des données je parie non ? Car dans ce cas vous avez raison (sauf sur le Null)
Pour que cela fonctionne,il faut au départ que la table soit vide.
Créer une table, avec un champ "ID", vous ne choisissez pas "Numéro auto" mais une valeur numérique ou de type texte et vous définissez ce champ comme étant la clé primaire.
Remplissez la table et vous verrez que cela fonctionne très bien.
Si vous ne pouvez pas partir d'une table vide, il suffit de définir votre champ comme "unique", cela aura le même effet que la clé primaire.
bonjour
Merci de ton aide.
Cela ne fonctionne pas.
Clé primaire, champ1 et champ2 sont numerique.
Mon formulaire est basé sur la requete de concaténation.
Lorsque les champs 1 et 2 sont remplis, la concaténation se fait bien, champ primaire se rempli mais c'est a ce moment que j'ai ce fameux message d'erreurs.
Au départ ma table est vide.
Merci de ton aide.
Cela ne fonctionne pas.
Clé primaire, champ1 et champ2 sont numerique.
Mon formulaire est basé sur la requete de concaténation.
Lorsque les champs 1 et 2 sont remplis, la concaténation se fait bien, champ primaire se rempli mais c'est a ce moment que j'ai ce fameux message d'erreurs.
Au départ ma table est vide.
Quel est ce message d'erreur ?
Petit truc pour éviter le problème d'une valeur Null avec une autre, il suffit d'ajouter à côté une zone vide :
txtChamp1 & "" & txtChamp2 & ""
Petit truc pour éviter le problème d'une valeur Null avec une autre, il suffit d'ajouter à côté une zone vide :
txtChamp1 & "" & txtChamp2 & ""
Bonjou
Un index ou une cle primaire ne peut contenir une valeur Nul
Voila pour le message d'erreur
Ma ligne de contatenation
NomClePrimaire: [Champ1]&""&[champ2]
pour toi il faudrait ecrire
NomClePrimaire: [Champ1]&""&[champ2] & ""
mais cela ne fonctionne pas
Un index ou une cle primaire ne peut contenir une valeur Nul
Voila pour le message d'erreur
Ma ligne de contatenation
NomClePrimaire: [Champ1]&""&[champ2]
pour toi il faudrait ecrire
NomClePrimaire: [Champ1]&""&[champ2] & ""
mais cela ne fonctionne pas
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Si Access détecte une valeur Null c'est que la concaténation des champs 1 et 2 est une valeur Null, y a pas photo
Il faut déboguer et vérifier les valeurs avant la mise à jour.
Pour cela vous allez utiliser l'évènement Before_Update (Avant MAJ) :
Je ne connais pas les noms des champs dans le formulaire, je les appellerai donc txtChamp1 pour la valeur du Champ1 et txtChamp2 pour la valeur du Champ2 :
Sub Before_Update(Cancal as Integer)
If IsNull(txtChamp1) Then
MsgBox "Attention le champ txtChamp1 est Null !"
Cancel = True 'Abandonner la mise à jour
End If
If IsNull(txtChamp2) Then
MsgBox "Attention le champ txtChamp2 est Null !"
Cancel = True
End If
End Sub
Essayez ça.
Il faut déboguer et vérifier les valeurs avant la mise à jour.
Pour cela vous allez utiliser l'évènement Before_Update (Avant MAJ) :
Je ne connais pas les noms des champs dans le formulaire, je les appellerai donc txtChamp1 pour la valeur du Champ1 et txtChamp2 pour la valeur du Champ2 :
Sub Before_Update(Cancal as Integer)
If IsNull(txtChamp1) Then
MsgBox "Attention le champ txtChamp1 est Null !"
Cancel = True 'Abandonner la mise à jour
End If
If IsNull(txtChamp2) Then
MsgBox "Attention le champ txtChamp2 est Null !"
Cancel = True
End If
End Sub
Essayez ça.
Bonjour
Merci pour ton aide
Voici un lien d'un exemple pour utiliser le principe de concaténation sur un clé primaire.
Dans le formulaire issu de la requete, j'inscris une date que me transforme en N°jours. J'inscris IdDate
Le resultat s'affiche dans N°List
Lorsque je veux faire un 2eme enregistrement message d'erreur.
Voic le lien
https://www.cjoint.com/?BEkkkU3qEAK
Merci pour ton aide
Voici un lien d'un exemple pour utiliser le principe de concaténation sur un clé primaire.
Dans le formulaire issu de la requete, j'inscris une date que me transforme en N°jours. J'inscris IdDate
Le resultat s'affiche dans N°List
Lorsque je veux faire un 2eme enregistrement message d'erreur.
Voic le lien
https://www.cjoint.com/?BEkkkU3qEAK
Voilà, envoyez moi votre adresse e-mail et je vous renvoie la base corrigée avec un formulaire en exemple.
Bonjour
Je te remercie pour l'aide.
Maintenant peux tu m'expliquer pour realiser le principe dans une autre base de données?
J'ai bien vu que N°List a étè modifié en texte et indexé sans doublons.
La Concaténation se fait comment.?
Je te remercie pour l'aide.
Maintenant peux tu m'expliquer pour realiser le principe dans une autre base de données?
J'ai bien vu que N°List a étè modifié en texte et indexé sans doublons.
La Concaténation se fait comment.?
Hello Castours,
Mon intervention ne ressoudera pas ton problème de concaténation.
Simplement pour dire que je vois beaucoup de post à ce sujet un peu partout sur la toile.
A propos d'une clé primaire, elle doit être complètement indépendante des données métier, donc non issue de concaténation ou de valeurs provenant d'une ligne. Les clés étrangères s'appuient sur les clés primaires pour établir les relations entre les tables de la base de données. Que se passe t-il le jour ou les valeurs de colonnes qui ont servi à créer la clé primaire doivent changer ? La base de données s'écroule...?
DROE
Mon intervention ne ressoudera pas ton problème de concaténation.
Simplement pour dire que je vois beaucoup de post à ce sujet un peu partout sur la toile.
A propos d'une clé primaire, elle doit être complètement indépendante des données métier, donc non issue de concaténation ou de valeurs provenant d'une ligne. Les clés étrangères s'appuient sur les clés primaires pour établir les relations entre les tables de la base de données. Que se passe t-il le jour ou les valeurs de colonnes qui ont servi à créer la clé primaire doivent changer ? La base de données s'écroule...?
DROE
Bonjour
Merci de ta participation.
Les données sont issues du N°du jour de l'année sur la saisie d'une date aprés extration.
Le 2eme est la clé secondaire de mon formulaire principale
La concaténation forme la clé primaire des enregistrement de mon sous formulaire.
Donc je crois qu'il ne devrait pas avoir de probleme par la suite.
Merci de ta participation.
Les données sont issues du N°du jour de l'année sur la saisie d'une date aprés extration.
Le 2eme est la clé secondaire de mon formulaire principale
La concaténation forme la clé primaire des enregistrement de mon sous formulaire.
Donc je crois qu'il ne devrait pas avoir de probleme par la suite.