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

Langage SQL Discussion :

[Access] INSERT complexe


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Juillet 2006
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 59
    Par défaut [Access] INSERT complexe
    Bonsoir,

    J'ai un problème lors d'une restructuration d'une base de donnée ACCESS. En effet, je dispose actuellement d'une table, qui contient toutes les informations. Il s'agit en fait de clients, mais dont toutes les informations sont stockées sur une table. Un des champs (en mémo) contient en fait les différentes visites, séparées par des retours à la ligne.
    Je souhaite donc mettre ces différentes informations dans une autre table, appelée Visites, avec en primary key le numéro de la visite, pour les classer, ensuite en clé étrangère (avec intégrité référentielle) le numéro associé au client (en auto-incrément et primary key sur la première table).

    Il faut donc faire un INSERT SELECT, avec une fonction pour découper la chaîne et qu'à chaque bout de chaine, ça crée une ligne dans la nouvelle table, avec le nom du client et une date, présente dans un autre champ (qui comporte les dates des différentes visites, séparées par des virgules) et d'autres infos, qui seront copiées comme telle dans la nouvelle table.

    Voila, si quelqu'un pouvait m'aider... ça m'éviterais un copier / coller fastidieux.

    Bonne journée

  2. #2
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 288
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 288
    Par défaut
    si tu
    connais le VBA, il faut que tu fasses une Sub qui lise ta table, effectue un Split() de ton Mémo à chaque ligne et pilote les insertions.

    Sinon, tu exportes dans un fichier texte, où tu remplace les retours à la ligne (carac 10) par des retours chariot. tu n'a plus ensuite qu'à ré-importer ce fichier dans ta base.

  3. #3
    Membre averti
    Inscrit en
    Juillet 2006
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 59
    Par défaut
    Bonjour,

    Oui, j'avais entendu de cette fonction split qu'on peut utiliser sous VBA, et j'aimerais effectivement faire ce transfert avec l'aide de VBA, mais j'aimerais avoir quelques pistes pour me lancer. En fait, je trouverais aisément les paramètres nécessaires à cette fonction, mais ce que je ne saurais pas faire, c'est l'insertion dans la table qui sera dans la boucle.
    Est-ce du SQL bête et méchant ?

    Bonne journée

  4. #4
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 288
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 288
    Par défaut
    mais ce que je ne saurais pas faire, c'est l'insertion dans la table qui sera dans la boucle.
    Est-ce du SQL bête et méchant ?
    yep... si tu sais accéder aux données avec VBA, tu n'as plus qu'à faire du .Execute "INSERT INTO...".

  5. #5
    Membre averti
    Inscrit en
    Juillet 2006
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 59
    Par défaut
    Bonjour,

    Malgré tout, je veux bien si cela est possible, un exemple, avec des noms de champs fictifs, pour ce type d'insertion... parce que ça ne me semble pas simple du tout.

  6. #6
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 288
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 288
    Par défaut
    Peux-tu me donner un exemple de tes données à splitter ?

    Connais-tu l'accès aux données en VB (avec l'ADO ou le DAO) ?

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

Discussions similaires

  1. PB requete access : insertion de données et somme
    Par pierrickbe dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 18/07/2008, 14h18
  2. ACCESS Insert et select
    Par Spanish_ dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 02/01/2008, 16h00
  3. [ODBC] [Access] Insertion avec NumeroAuto
    Par Aillyzeux dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 30/08/2007, 11h25
  4. [ACCESS] Insert - Select
    Par diaboloche dans le forum Langage SQL
    Réponses: 3
    Dernier message: 16/02/2007, 16h30
  5. [vb][access] Insert
    Par Alex35 dans le forum VBA Access
    Réponses: 1
    Dernier message: 12/12/2005, 11h41

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