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 :

Convertir une requête SQL Server en requête Access


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Inscrit en
    Avril 2007
    Messages
    1 247
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 1 247
    Par défaut Convertir une requête SQL Server en requête Access
    Bonjour,
    Un collègue m'a refilé une requête sql server.
    J'essaie de la retranscrire en sql access mais en vain.
    J'ai un message d'erreur
    " erreur de synthaxe dans la clause FROM"
    Pourriez-vous m'aidez..merci

    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
    SELECT DisplayName, Sum (c1) AS keyboard, Sum(c2) AS OHScanner, SUM(c3) AS HHScanner, SUM(c4) AS Stray,SUM(c5) AS Fragile, SUM(c6) AS Cylindrical,SUM(c7) AS OverSize , SUM (c1) + SUM(c2) + SUM(c4) + SUM(c5) + SUM(c6) + SUM(c7) AS Total
     
     
    FROM (SELECT p.DisplayName,COUNT(*) AS c1,0 AS c2,0 As c3,0 AS c4,0 As c5,0 AS c6, 0 As c7,0 AS c8,0 AS c9
     
                      FROM dbo_vwItemEventHistory  with inner join dbo_vwItemData as id with on dbo_vwItemEventHistory.itemid=id.itemid inner join dbo_vwItemData as p with on id.inductionPartId=p.id
    where( dbo_vwItemEventHistory.ItemEventTypeId=5) AND (dbo_vwItemEventHistory.EventTime>=#4/25/2014 10:0:0#) And (dbo_vwItemEventHistory.EventTime<=#4/25/2014 11:0:0#) AND( id.inductionMode='Keyboard') 
     
    Group BY p.Displayname
     
    Union
     
    SELECT p. DisplayName,0 AS c1, count (*) AS c1,0 AS c2,0 As c3,0 AS c4,0 As c5,0 AS c6, 0 As c7,0 AS c8,0 AS c9
     
    FROM dbo_vwItemEventHistory  with inner join dbo_vwItemData as id with on dbo_vwItemEventHistory.itemid=id.itemid inner join dbo_vwItemData as p with on id.inductionPartId=p.id
    where( dbo_vwItemEventHistory.ItemEventTypeId=5) AND (dbo_vwItemEventHistory.EventTime>=#4/25/2014 10:0:0#) And (dbo_vwItemEventHistory.EventTime<=#4/25/2014 11:0:0#) AND( id.inductionMode='scanner') 
    Group BY p.Displayname
     
    UNION
     
    SELECT p. DisplayName,0 AS c1, count (*) AS c1,0 AS c2,0 As c3,0 AS c4,0 As c5,0 AS c6, 0 As c7,0 AS c8,0 AS c9
     
    FROM dbo_vwItemEventHistory  with inner join dbo_vwItemData as id with on dbo_vwItemEventHistory.itemid=id.itemid inner join dbo_vwItemData as p with on id.inductionPartId=p.id
    where( dbo_vwItemEventHistory.ItemEventTypeId=5) AND (dbo_vwItemEventHistory.EventTime>=#4/25/2014 10:0:0#) And (dbo_vwItemEventHistory.EventTime<=#4/25/2014 11:0:0#) AND( id.inductionMode='HHScanner') 
    Group BY p.Displayname
     
    UNION
     
    SELECT p. DisplayName,0 AS c1, count (*) AS c1,0 AS c2,0 As c3,0 AS c4,0 As c5,0 AS c6, 0 As c7,0 AS c8,0 AS c9
    FROM dbo_vwItemEventHistory  with inner join dbo_vwItemData as id with on dbo_vwItemEventHistory.itemid=id.itemid inner join dbo_vwItemData as p with on id.inductionPartId=p.id
    where( dbo_vwItemEventHistory.ItemEventTypeId=5) AND (dbo_vwItemEventHistory.EventTime>=#4/25/2014 10:0:0#) And (dbo_vwItemEventHistory.EventTime<=#4/25/2014 11:0:0#) AND( id.inductionMode='Stray') 
    Group BY p.Displayname
     
    UNION
     
     
     
    SELECT p. DisplayName,0 AS c1, count (*) AS c1,0 AS c2,0 As c3,0 AS c4,0 As c5,0 AS c6, 0 As c7,0 AS c8,0 AS c9
    FROM dbo_vwItemEventHistory  with inner join dbo_vwItemData as id with on dbo_vwItemEventHistory.itemid=id.itemid inner join dbo_vwItemData as p with on id.inductionPartId=p.id
    where( dbo_vwItemEventHistory.ItemEventTypeId=5) AND (dbo_vwItemEventHistory.EventTime>=#4/25/2014 10:0:0#) And (dbo_vwItemEventHistory.EventTime<=#4/25/2014 11:0:0#) AND( id.inductionMode='fragile') 
    Group BY p.Displayname
     
    UNION
     
    SELECT p. DisplayName,0 AS c1, count (*) AS c1,0 AS c2,0 As c3,0 AS c4,0 As c5, SUM(CounterValue) AS c6, 0 As c7,0 AS c8,0 AS c9
    FROM dbo_vwPartCountsHistory AS ch WITH  INNER JOIN dbo_vwParts AS p WITH ON ch.partid=p.id
    where( dbo_vwPartCountsHistory.CounterTypeId=82/*Cylindrical*/) AND (dbo_vwPartCountsHistory.CounterTimeStamp>=#4/25/2014 10:0:0#) AND (dbo_vwPartCountsHistory.CounterTimeStamp<=#4/25/2014 11:0:0#)
     Group BY p.Displayname
     
    UNION
     
    SELECT p. DisplayName,0 AS c1, count (*) AS c1,0 AS c2,0 As c3,0 AS c4,0 As c5,  AS c6,SUM(CounterValue) As c7,0 AS c8,0 AS c9
    FROM dbo_vwPartCountsHistory AS ch WITH  INNER JOIN dbo_vwParts AS p WITH ON ch.partid=p.id
    where( dbo_vwPartCountsHistory.CounterTypeId=83/*OverSizel*/) AND (dbo_vwPartCountsHistory.CounterTimeStamp>=#4/25/2014 10:0:0#) AND (dbo_vwPartCountsHistory.CounterTimeStamp<=#4/25/2014 11:0:0#)
     Group BY p.Displayname

  2. #2
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 063
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 063
    Par défaut
    Bonjour,

    Après remise en forme de la requête, on s'aperçoit qu'elle n'est pas complète .
    Il manque au moins une parenthèse à la fin et un alias...

    De plus, je ne sais pas à quoi correspondent les WITH dans les jointures...
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  3. #3
    Membre éprouvé
    Inscrit en
    Avril 2007
    Messages
    1 247
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 1 247
    Par défaut
    bonjour ced,
    merci pour cette reponse..
    je vais revoir cette requete de A à Z..

  4. #4
    Membre éprouvé
    Inscrit en
    Avril 2007
    Messages
    1 247
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 1 247
    Par défaut
    Bonjour CED,

    Effectivement il manquait une parenthèse à la fin du code SQL.
    Lorsque tu écris
    il manque un alias à la fin
    qu'est-ce qu'un alias ?..

  5. #5
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 063
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 063
    Par défaut
    Vous les utilisez déjà : ... AS p par exemple.
    Mais comme vous faites une sous-requête dès le premier FROM, il vous faut un alias, ... AS t par exemple, derrière votre parenthèse finale (celle qui manque).
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  6. #6
    Membre éprouvé
    Inscrit en
    Avril 2007
    Messages
    1 247
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 1 247
    Par défaut
    CED,
    Lorsque j'affiche la requête sql en mode création, je vois afficher ma requête avec les champs et au-dessus des champs, j'ai une table vide nommée bizarrement
    %$##@_Alias
    Qu'est ce que cela signifie ???

  7. #7
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    13 217
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 13 217
    Billets dans le blog
    48
    Par défaut
    Cette table vide correspond justement à une sous-requête, lorsqu'il n'y a pas d'alias précisé l'assistant en rajoute un tout seul as Nom_d_Alias_a_la_#@¤$*.

  8. #8
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 063
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 063
    Par défaut
    Désolé, là, je passe la main. Je n'utilise pas et ne connais donc pas Access...
    Du coup, je ne sais pas à quoi ça correspond.
    C'est peut-être une question à poser sur le forum dédié aux requêtes Access.
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

Discussions similaires

  1. [CR 8] Question pour convertir une requete SQL SERVER en Requête CR
    Par nekro65 dans le forum SAP Crystal Reports
    Réponses: 11
    Dernier message: 24/06/2010, 11h37
  2. [AC-2007] mise à jour d'une table SQL server depuis MS Access
    Par avalenza dans le forum Projets ADP
    Réponses: 1
    Dernier message: 10/02/2010, 20h04
  3. Réponses: 3
    Dernier message: 04/06/2007, 12h29
  4. convertir une base sql server en base Access
    Par Smix007 dans le forum MS SQL Server
    Réponses: 7
    Dernier message: 06/05/2007, 11h44
  5. Réponses: 2
    Dernier message: 16/05/2006, 10h52

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