IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

VB.NET Discussion :

Champs obligatoire et unique (mais pas toujours) ds table Access


Sujet :

VB.NET

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    314
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Juin 2002
    Messages : 314
    Points : 99
    Points
    99
    Par défaut Champs obligatoire et unique (mais pas toujours) ds table Access
    Bonjour,

    Base Acess sous Vb.Net.

    J'ai dans cette base plusieurs tables identiques que je crée par code.

    Dans certaine table je dois dans un champs donné pouvoir saisir des nombre.
    Si ce champs doit être saisi il doit être non null et sans doublons.
    Peut on dans une table déja existante déclarer par code si un champs est unique et sans doublon.

    J'ouvre mes base avec une requête SQL.
    J'aimerai pouvoir contrôler la saisie de ce champs.

    Si c'est possible merci de m'indiquer une piste à suivre.

    Merci d'avance
    FikoU

  2. #2
    Membre chevronné
    Avatar de olsimare
    Inscrit en
    Décembre 2006
    Messages
    1 179
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 179
    Points : 1 777
    Points
    1 777
    Par défaut
    Bonjour.

    Désolé, mais c'est pas trés clair.

    Si le champ doit être unique et que tu créés la table par code (avec un CREATE TABLE Machin ...), pourquoi ne pas ajouter des contraintes (ADD CONSTRAINT bidule ... ).

    Sinon, tu peux le gérer lors de la création du dataset typé (si tu te sers d'un dataset typé) ou directement lors du validating de ton formulaire.

    Donc tu vois, plus de précision serait le bienvenu.

    Cdt.

  3. #3
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753
    Par défaut
    Citation Envoyé par olsimare Voir le message
    ADD CONSTRAINT bidule
    Mouais, faut pas oublier que c'est Access... je suis pas sûr que "ADD CONSTRAINT" soit supporté !

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    314
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Juin 2002
    Messages : 314
    Points : 99
    Points
    99
    Par défaut
    Bonjour,

    En fait lors de la création je ne sais pas encore si les champs de la table devront êtres obligatoire/unique.

    Peut on lors de l'ouverture de la table appliquer CONSTRAINT ???

    Comme ce n'est pas des tables très grandes (pas plus de 50/60 enregistrements) Une autre solution serai d'utiliser un tableau et de remplir après la table. Mais comment gérer uue valeur unique lors de la saisie d'un tab ???

    Merci à tous

    FikoU

  5. #5
    Membre chevronné
    Avatar de olsimare
    Inscrit en
    Décembre 2006
    Messages
    1 179
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 179
    Points : 1 777
    Points
    1 777
    Par défaut
    Bonjour.

    Alors, il faut jouer sur les propriétés des datacolumns de la datatable que tu récupéres.

    Cdt.

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    314
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Juin 2002
    Messages : 314
    Points : 99
    Points
    99
    Par défaut
    Bonjour,

    olsimare a dit :

    Alors, il faut jouer sur les propriétés des datacolumns de la datatable que tu récupéres.
    Peut tu m'en dire plus (un p'tit bout de code).

    FikoU

  7. #7
    Membre chevronné
    Avatar de olsimare
    Inscrit en
    Décembre 2006
    Messages
    1 179
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 179
    Points : 1 777
    Points
    1 777
    Par défaut
    Bonjour.

    Par exemple, avec un datagridview alimenté par une datatable créée "à la main" :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
            Dim dt As New DataTable
            dt.Columns.Add("C1")
            dt.Columns.Add("C2")
            dt.Columns("C1").Unique = True
            dt.Columns("C2").AllowDBNull = False
            Me.DataGridView1.DataSource = dt
    Donc le .Unique et le .AllowDBNull doivent pouvoir te convenir.

    Cdt.

  8. #8
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    314
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Juin 2002
    Messages : 314
    Points : 99
    Points
    99
    Par défaut
    OK merci olsimare,

    Je commence à y voir plus clair.
    Je gère la saisie avec un try ??

    Je testerai ce week (programmeur du dimanche)

    @+FikoU

  9. #9
    Membre chevronné
    Avatar de olsimare
    Inscrit en
    Décembre 2006
    Messages
    1 179
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 179
    Points : 1 777
    Points
    1 777
    Par défaut
    Bonjour.

    Pour la gestion de l'erreur, ça dépend du composant de saisi.

    Si c'est un datagridview, tu as l'event DataError qui peut être utile.

    A titre personnel, je me suis fais une class de validation des données à partir du schema de la table car les exceptions levées me semble complétement inexploitable et tester les champs en erreur un par un c'est un peu lourd.

    Mais si quelqu'un connaît une solution plus simple, je suis aussi preneur !

    Nota : je suis programmeur du soir moi !

    Cdt.

Discussions similaires

  1. Réponses: 1
    Dernier message: 28/01/2009, 15h33
  2. [AJAX] xhr.status = 0, Mais pas toujours :~
    Par Terni dans le forum Général JavaScript
    Réponses: 0
    Dernier message: 29/10/2008, 16h12
  3. [E-03] Tableau dans lequel on supprime les doublons mais pas toujours
    Par edonist dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 08/10/2008, 22h38
  4. CSS oui, mais pas toujours
    Par Michel Rotta dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 02/11/2007, 10h29
  5. Réponses: 9
    Dernier message: 25/07/2007, 14h02

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo