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

VBA Access Discussion :

Utilisation fonction CreateRelation de l'objet database [Toutes versions]


Sujet :

VBA Access

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Gestionnaire de parc micro-informatique
    Inscrit en
    Avril 2018
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestionnaire de parc micro-informatique
    Secteur : Distribution

    Informations forums :
    Inscription : Avril 2018
    Messages : 5
    Par défaut Utilisation fonction CreateRelation de l'objet database
    Bonjour,

    Je trouve l'exemple du tuto Microsoft vraiment pas clair. Notamment dans la distinction clef primaire clef secondaire et ce besoin de créer des objets tables, champs et index temporaires alors que je souhaite partir de l'existant.

    Si quelqu'un avait un exemple simple avec tables existantes correctement définies avec une table primaire et sa clé, et table primaire avec champs joints de même type.

    Et surtout des noms distincts et significatifs pour chaque élément.

    Merci de votre et meilleurs vœux.

    Fran.

    Le tuto en question que je trouve bien lourd pour seulement quelques lignes significatives.
    https://learn.microsoft.com/fr-fr/of...ion-method-dao

    Il y a en effet une ligne qui me semble être en dur, deuxième ligne :
    relNew.Fields.Append relNew.CreateField("DeptID")
    relNew.Fields!DeptID.ForeignName = "DeptID"

  2. #2
    Expert confirmé

    Homme Profil pro
    consultant développeur
    Inscrit en
    Mai 2005
    Messages
    3 045
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : consultant développeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 045
    Par défaut
    Bonjour Fran45,
    Voici 3 fonctions qui devraient aider
    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
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    	 Public Function TableRelationIntRef_create(oDb1 As dao.Database, primaryTableName As String, primaryFieldName As String, foreignTableName As String, foreignFieldName As String) As Boolean
    'Usage: Call TableRelationIntRef_create(oDb1,"Table1", "EMP_ID", "Table2", "EMP_ID")
    
        On Error GoTo ErrHandler
        'Dim odb1 As DAO.Database
        Dim newRel As dao.Relation
        Dim relatingField As dao.Field
        Dim relationUniqueName As String
        relationUniqueName = primaryTableName + "_" + primaryFieldName + "__" + foreignTableName + "_" + foreignFieldName
    
        '   'Set oDb1 = CurrentDb()
        '     ' base remote à modifier
        '    Set oDb1 = GetLinkedTable_DbSource(primaryTableName)
    
        Set newRel = oDb1.CreateRelation(relationUniqueName, primaryTableName, foreignTableName)
        Set relatingField = newRel.CreateField(primaryFieldName)
        relatingField.ForeignName = foreignFieldName
        newRel.Fields.Append relatingField
        newRel.Attributes = dbRelationUpdateCascade Or dbRelationDeleteCascade    'dbRelationLeft Or dbRelationDeleteCascade
    
        oDb1.Relations.Append newRel  'erreur 3201 est levée
        'Set odb1 = Nothing
        TableRelationIntRef_create = True
        Exit Function
    
    ErrHandler:
        Debug.Print "erreur " & err.Number, err.description, " (" + relationUniqueName + ")"
        TableRelationIntRef_create = False
    End Function
    
    Public Function TableRelations_delete(oDb As dao.Database, _
                                          strNomTable As String) As Integer
    ' 2019-03-19     La fonction retourne le nombre de relations supprimées.
    '               Usage:    TableRelations_delete(oDb, "T_Client")
    '                       pour supprimer les relations de la table T_Client
        Dim oRlt As dao.Relation
        'Pour chaque relation,
        For Each oRlt In oDb.Relations
            'si la table est utilisée
            If oRlt.Table = strNomTable Or oRlt.ForeignTable = strNomTable Then
                'Supprime la relation
                Debug.Print "relation supprimée : " & oRlt.Name
                oDb.Relations.Delete oRlt.Name
                oDb.Relations.Refresh
                'Incrémente le compteur
                TableRelations_delete = TableRelations_delete + 1
            End If
        Next oRlt
    End Function
    
    Public Function TableRelations_count(oDb As dao.Database, _
                                         strNomTable As String) As Integer
    ' 2019-03-21     La fonction retourne le nombre de relations existantes sur une table  
    '   Usage   : TableRelations_count(oDb, "T_data_ayantDroit")
    
        Dim oRlt As dao.Relation, n As Integer
        n = 0
        For Each oRlt In oDb.Relations
            'si la table est utilisée
            If oRlt.Table = strNomTable Or oRlt.ForeignTable = strNomTable Then
                Debug.Print "relation : " & oRlt.Name
                'Incrémente le compteur
                n = n + 1
            End If
        Next oRlt
        TableRelations_count = n
    End Function

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Gestionnaire de parc micro-informatique
    Inscrit en
    Avril 2018
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestionnaire de parc micro-informatique
    Secteur : Distribution

    Informations forums :
    Inscription : Avril 2018
    Messages : 5
    Par défaut
    Impeccable.
    Merci micniv.

    Partie du code que j'ai repris in extenso, il fallait passer par un objet field intermédiaire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
        Set newRel = oDb1.CreateRelation(relationUniqueName, primaryTableName, foreignTableName)
        Set relatingField = newRel.CreateField(primaryFieldName)
        relatingField.ForeignName = foreignFieldName
        newRel.Fields.Append relatingField
        newRel.Attributes = dbRelationUpdateCascade Or dbRelationDeleteCascade    'dbRelationLeft Or dbRelationDeleteCascade
     
        oDb1.Relations.Append newRel  'erreur 3201 est levée

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Pb de blancs dans utilisation fonction FtpFindFirstFile
    Par AlvinTheMaker dans le forum MFC
    Réponses: 2
    Dernier message: 06/04/2005, 12h33
  2. Réponses: 6
    Dernier message: 24/02/2005, 09h44
  3. [GIMP] [Script-FU] Utilisation fonction gimp-curves-spline
    Par narmataru dans le forum Autres langages
    Réponses: 1
    Dernier message: 09/02/2005, 17h25
  4. [Débutant] Aide utilisation fonctions :(
    Par trakiss dans le forum Débuter
    Réponses: 10
    Dernier message: 27/08/2004, 15h59
  5. Utilisation fonction définie dans un .Dll
    Par jeab. dans le forum Windows
    Réponses: 5
    Dernier message: 23/03/2004, 16h23

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