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

MS SQL Server Discussion :

Lier un fichier Access accdb à une base SQL Server [2017]


Sujet :

MS SQL Server

  1. #1
    Membre habitué Avatar de harpyopsis
    Homme Profil pro
    Vétérinaire
    Inscrit en
    Octobre 2015
    Messages
    143
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 66
    Localisation : Indonésie

    Informations professionnelles :
    Activité : Vétérinaire
    Secteur : Santé

    Informations forums :
    Inscription : Octobre 2015
    Messages : 143
    Points : 187
    Points
    187
    Par défaut Lier un fichier Access accdb à une base SQL Server
    Hello les Docteurs SQL !

    Je viens de me préparer une nouvelle installation sur PC portable avec
    • Windows 10,
    • MS SQL Server Developer 2019,
    • MS SS Management Studio v18.5
    • MS SS Migration Assistant for Access v8.10.0
    • Access Runtime 2016
    • Office Enterprise 2007 (32bits..., je n'ai rien d'autre sous la main)
    • Je n'y ai pas encore installé SQL Server Express

    Sur ce dispositif, la migration des Tables accdb 2007 avec SSMA vers une mdf fraîche SQL Server se passe très bien. C'est plus rapide que l'importation de données via SSMS Server Express. Les Tables obtenues semblent propres (pas de SSMA_TimeStamp, par exemple).

    Question :

    Quelle est selon vous la meilleure méthode pour lier ces tables SQL Server dans un nouveau fichier accdb vide ?


    J'ai essayé

    1- A partir de SS Management Studio
    • Tâches
    • Exportation de données
    • Source : SQL Server Native Client 11.0
    • Destination : Microsoft Access DB Engine
    • Copy Data
      Problème : Triangle jaune : le type de données Mémo source est "nvarchar" incompatible avec le type de données destination "Long Text". Echec... La table résultante dans Access est vide... A quoi est du cet échec ??? Pourquoi Import Export Wizard n'harmonise-t-il pas automatiquement les types de données??? Les Tables accdb 2007 viennent de Tables plus anciennes mdb 2003, converties par Access 2007.


    2- A partir d'Access : Link to ODBC Database
    • Source de données fichier, File Data Source
      Cela fonctionnait bien sur une autre machine avec SQL Server Express pour aller chercher le fichier *mdf.dsn.
      Mais maintenant avec Developer 2019, le dsn me propose invariablement de lier ceci :


      Nom : FileDataS.JPG
Affichages : 1493
Taille : 67,9 Ko
      Impraticable ! Pourtant ça devrait marcher comme avant ! Que se passe-t-il ?

    • Source de données machine, Machine Data Source
      Je suis donc allé créer un nouveau driver nommé "test" (je ne sais pas si je m'exprime bien) selon les tutos en bas de page.

      Et là, ça marche !
      Les Tables obtenues sont correctes, complètes, et les Mémos ne sont pas tronqués...
      Simplement, elles sont encore une fois renommées dbo_* comme dans mon dernier post https://www.developpez.net/forums/d2...o-automatique/ mais c'est un écueil mineur.
      Cependant, je ne me voit pas créer un tel driver au moment de l'installation sur les machines des autres utilisateurs....



    Voilà. Quel est votre avis ?

    Existe-t-il vraiment une méthode 100% sûre que vous pourriez me recommander ???
    Doit-on parfois se résoudre à d'horribles manipulations comme celle-ci : https://www.sqlservercentral.com/for...x-field-in-sql ?

    A vous et merci !

    phil




  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 761
    Points : 52 547
    Points
    52 547
    Billets dans le blog
    5
    Par défaut
    Effectivement il faut nettoyer les scories....

    Pour cela un petit programmes de migration peut être édité en VBA.

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Membre habitué Avatar de harpyopsis
    Homme Profil pro
    Vétérinaire
    Inscrit en
    Octobre 2015
    Messages
    143
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 66
    Localisation : Indonésie

    Informations professionnelles :
    Activité : Vétérinaire
    Secteur : Santé

    Informations forums :
    Inscription : Octobre 2015
    Messages : 143
    Points : 187
    Points
    187
    Par défaut
    Ok, on fait comme ça ! Données machine avec driver local, et loop vba pour renommer les Tables liées.

    Frédéric, stp : comment interprètes-tu la liste aberrante que me donne à présent la source de données fichier ???

    Encore merci !

    A+

  4. #4
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 761
    Points : 52 547
    Points
    52 547
    Billets dans le blog
    5
    Par défaut
    Citation Envoyé par harpyopsis Voir le message
    ...
    Frédéric, stp : comment interprètes-tu la liste aberrante que me donne à présent la source de données fichier ???
    La liste n'est pas aberrante mais logique et vous la trouvez quelque peu gênante...
    1) les objets tables dans le schéma "sys" sont des objets systèmes propriétaires (Microsoft) de type vues (TABLE_TYPE = VIEW).
    2) les objets tables dans le schéma "INFORMATION_SCHEMA" sont des objets systèmes normalisées (norme SQL) de type vues (TABLE_TYPE = VIEW).
    Le tout peut être remonté dans votre application Access... C'est pourquoi la liste présente TOUS les objets accessibles et non pas que les objets créés par l'utilisateur...

    Cela résulte de la règle n°4 de Codd (créteurs des SGBD Relationnels). Une petite explication est données dans mon futur livre sur SQL :
    Nom : Codd regle 4.jpg
Affichages : 1365
Taille : 295,8 Ko

    Ces vues (car il ne s'agit pas de tables permettent de décrire l'intégralité de la structure d'une base et facilite grandement la vie du développeur qui ne doit plus faire que des requêtes et rien d'autres (règle 0 de Codd).

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  5. #5
    Membre habitué Avatar de harpyopsis
    Homme Profil pro
    Vétérinaire
    Inscrit en
    Octobre 2015
    Messages
    143
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 66
    Localisation : Indonésie

    Informations professionnelles :
    Activité : Vétérinaire
    Secteur : Santé

    Informations forums :
    Inscription : Octobre 2015
    Messages : 143
    Points : 187
    Points
    187
    Par défaut
    Oke, merci !

    Donc si je comprends bien : toute Table liée dans un fichier accdb, est en fait une Vue...

    C'est logique. Mais le dialogue de Access parle pourtant bien de Tables. D'où la confusion qui se maintient chez les béotiens comme moi.

    Je dormirai moins bête ce soir ! Une vie ne suffirait pas à apprendre tout ce qu'il faudrait savoir !

    A+

  6. #6
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 761
    Points : 52 547
    Points
    52 547
    Billets dans le blog
    5
    Par défaut
    NON, non.... pas tout à fait.
    Une vue est un objet de la base de données pas de l'applicatif.
    Access mélange applicatif et BD, d'ou votre confusion.
    Dans Access, il n'existe pas de notion de vue à ma connaissances.
    CREATE VIEW n'est pas une instruction reconnue par Access.
    Access n'a que des tables et des objets de visualisation graphique des données.
    Une vue est un objet logique de présentation non graphique (aucun affichage). Mais une vue permet de mieux organiser l'information. par exemple, pré établit de multiples jointures de tables entre elles, synthétiser des informations, agréger des calculs....

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  7. #7
    Membre habitué Avatar de harpyopsis
    Homme Profil pro
    Vétérinaire
    Inscrit en
    Octobre 2015
    Messages
    143
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 66
    Localisation : Indonésie

    Informations professionnelles :
    Activité : Vétérinaire
    Secteur : Santé

    Informations forums :
    Inscription : Octobre 2015
    Messages : 143
    Points : 187
    Points
    187
    Par défaut
    Okay, merci beaucoup Frédéric...!

    J'ai potassé hier soir, j'en étais encore à croire que Vue et Query étaient des synonymes ! Je me réveille un peu moins bête ce matin !

    Entre Access et SQL Server on en arrive parfois à ne plus savoir où se trouvent réellement les données !

    Voir l'exemple d'il y a quelques jours avec docmd.CopyObject et DoCmd.TransferDatabase acImport... Ainsi lorsqu'on veut permettre à l'utilisateur de gérer ses propres backups de tarifs anciens, il existe trente-six milles méthodes, mais quelle est la meilleure ??? (Ce sera pour plus tard !!!)

    L'important maintenant est d'arriver à répliquer correctement les données entre les utilisateurs, puis avec l'hébergeur. On n'est pas rendus, single-handed !

    Aujourd'hui j'attaque la réplication de fusion entre les DB de deux utilisateurs sur SQL Server par clef USB. Je potasse... Ca marchait si bien avec JRO sur Access 2000-2003...! Je posterai mes questions stupides sur un nouveau fil !

    A+

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 23/12/2015, 11h54
  2. Réponses: 0
    Dernier message: 21/04/2008, 19h08
  3. Réponses: 19
    Dernier message: 01/02/2008, 11h54
  4. Réponses: 3
    Dernier message: 27/07/2007, 13h06
  5. Migrer un fichier excel vers une base sql serveur
    Par vdavid1982 dans le forum Langage SQL
    Réponses: 1
    Dernier message: 12/07/2005, 16h26

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