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

Accès aux données Discussion :

[VB.NET] AutoIncrement sur une column


Sujet :

Accès aux données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    164
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 164
    Par défaut [VB.NET] AutoIncrement sur une column
    Bonjour à tous

    Une petite question, j'aimerai créer un AutoIncrement sur une Column, mais je n'y arrive pas.
    Quelqu'un peut m'aider. Voici mon code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    Dim LaDB As String = application.StartupPath + "\MaBase.mdb"
    
    Dim ADOXcatalog As New ADOX.Catalog
    Dim ADOXtable As New ADOX.Table
    Dim ADOXindex As New ADOX.Index
    
    ADOXcatalog.Create("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & LaDB)
    ADOXcatalog.ActiveConnection =  "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & LaDB
    
            
    ADOXtable.Name = "Membres"
    ADOXtable.Columns.Append("Licence", ADOX.DataTypeEnum.adVarWChar, 7)
    ADOXtable.Columns.Append("Nom", ADOX.DataTypeEnum.adVarWChar, 30)
    ADOXtable.Columns.Append("Prenom", ADOX.DataTypeEnum.adVarWChar, 30)
    
    ADOXtable.Columns.Append("Id", ADOX.DataTypeEnum.adInteger) 'Je voudrai l'autoIcrement ici ;) 
    
    ADOXcatalog.Tables.Append(ADOXtable)
    ADOXindex.Columns.Append("Licence")
    ADOXtable.Indexes.Append(ADOXindex)
    
    	
    ADOXtable = Nothing
    ADOXindex = Nothing
    ADOXcatalog = Nothing
    Merci d'avance

    Pascal

  2. #2
    Expert confirmé
    Avatar de bidou
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mai 2002
    Messages
    3 055
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Transports

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 055
    Par défaut
    un machin du genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    With ADOXtable.Columns("Id")
        .Properties("Autoincrement") = True
        .Properties("Seed") = 1
        .Properties("Increment") = 1
    End With

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    164
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 164
    Par défaut Ca me cause ...
    Merci

    Juste un petit détail, là on donne les propriété pour "Id".
    Pour l'ajouter à ma table, je conserve ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ADOXtable.Columns.Append("Id", ADOX.DataTypeEnum.adInteger)
    Le code doit-il resembler à ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    ...
    DOXtable.Name = "Membres"
    ADOXtable.Columns.Append("Licence", ADOX.DataTypeEnum.adVarWChar, 7)
    ADOXtable.Columns.Append("Nom", ADOX.DataTypeEnum.adVarWChar, 30)
    ADOXtable.Columns.Append("Prenom", ADOX.DataTypeEnum.adVarWChar, 30)
    With ADOXtable.Columns("Id")
        .Properties("Autoincrement") = True
        .Properties("Seed") = 1
        .Properties("Increment") = 1
    End With
    ADOXtable.Columns.Append("Id", ADOX.DataTypeEnum.adInteger) 
    ...
    Pascal

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    164
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 164
    Par défaut Ca bug ...
    à la compilation j'ai le message suivant:
    La propriété 'Item' est 'ReadOnly' pour les 3 .Properties
    Que je place ce code avant ou aprés append


    Pascal

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Août 2006
    Messages
    27
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 27
    Par défaut
    pareil que toi, il me dit readonly, pas moyen de definir la propriété autoincrement

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Août 2006
    Messages
    27
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 27
    Par défaut
    bon voila mon code: il ne marche pas mais ne fait plus d'erreur à la compilation

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    tbl = New ADOX.Table
    tbl.Name = "editeur"
    'création du champs id autoincrement
    col = New ADOX.Column
    With col
         .ParentCatalog = cat
         .Name = "id"
         .Type = ADOX.DataTypeEnum.adInteger
         'TODO METTRE EN PLACE LE CHAMPS AUTOINCREMENT
         .Properties("Autoincrement").Value = 1
    End With
    tbl.Columns.Append(col)
    tbl.Keys.Append("PrimaryKey", ADOX.KeyTypeEnum.adKeyPrimary, "id")
    tbl.Columns.Append("nom", ADOX.DataTypeEnum.adVarWChar, 255)
    tbl.Columns.Append("pays", ADOX.DataTypeEnum.adVarWChar, 255)
    'TODO TODO Création de la table
    Try
        cat.Tables.Append(tbl)
    Catch ex As Exception
    l'exception contient ceci:

    Une opération OLE-DB en plusieurs étapes a généré des erreurs. Vérifiez chaque valeur d'état OLE-DB disponible. Aucun travail n'a été effectué.
    je comprend plus rien là

Discussions similaires

  1. [VB.NET] Erreur sur une page
    Par Azephel dans le forum ASP.NET
    Réponses: 8
    Dernier message: 13/04/2007, 09h01
  2. [VB.NET] Listview sur une colonne
    Par olbi dans le forum Windows Forms
    Réponses: 1
    Dernier message: 09/05/2006, 10h41
  3. [VB.NET] Probleme sur une DropDownList
    Par xG-Hannibal dans le forum ASP.NET
    Réponses: 4
    Dernier message: 10/01/2006, 11h08
  4. [VB.NET]Cliquer sur une ligne du datagrid
    Par Dnx dans le forum ASP.NET
    Réponses: 1
    Dernier message: 02/11/2005, 14h26
  5. [VB.NET] Contextmenu sur une DataGrid
    Par sinoo dans le forum Windows Forms
    Réponses: 2
    Dernier message: 29/07/2005, 19h51

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