Partage
  • Partager sur Facebook
  • Partager sur Twitter

Problème base de donnée

aide

Sujet résolu
    14 février 2023 à 10:16:36

    Bonjour, lorsque je clique sur un bouton dans une catégorie sur mon site j'obtiens cette erreur la et je n'arrive pas à la régler. Pouvez-vous m'aider?

    Voici ce que j'ai, merci d'avance :

    Not unique table/alias: 'article_froid'

    SELECT DISTINCT a.artid FROM article a INNER JOIN article_marque am USING(artid) INNER JOIN article_froid USING(artid) INNER JOIN article_froid USING(artid) WHERE 1 AND (a.catid IN ('368') OR (SELECT COUNT(artid) FROM vcategorie WHERE catid IN ('368') AND artid=a.artid)>0) AND a.pro IN ('1','3') AND am.marqueid IN ('17') AND article_froid.volume_cavite IN('244') AND ( SELECT COUNT(artid) FROM articlerecherche_finition WHERE finitionid IN ('1') AND artid = a.artid ) > 0 AND (SELECT COUNT(artid) FROM article_site a_s WHERE a_s.artid=a.artid AND a_s.active IN (1) AND a_s.site_code IN ('base'))>0 AND paysfabrication IN ('1') AND (SELECT COUNT(artid) FROM article_deselection WHERE artid=a.artid)=0 ORDER BY ventes DESC, stock DESC


    • Partager sur Facebook
    • Partager sur Twitter
      14 février 2023 à 11:13:56

      Il te dit que article_froid apparaît plus d'une fois dans la requête :

      > INNER JOIN article_froid USING(artid) INNER JOIN article_froid USING(artid)

      Erreur de c/c visiblement.

      • Partager sur Facebook
      • Partager sur Twitter
        14 février 2023 à 11:31:54

        julp a écrit:

        Il te dit que article_froid apparaît plus d'une fois dans la requête :

        > INNER JOIN article_froid USING(artid) INNER JOIN article_froid USING(artid)

        Erreur de c/c visiblement.


        C'est donc qu'on ne peut pas faire la jointure entre deux même chose logiquement donc un problème de c/c en effet...

        Si j'ai bien compris ce que tu dis juste au dessus.

        • Partager sur Facebook
        • Partager sur Twitter
          14 février 2023 à 11:49:18

          Si on pourrait parfaitement joindre deux fois la même table mais dans ce cas elles doivent avoir des alias différents (et la condition de jointure serait différente).

          Là on a deux fois strictement la même jointure donc il y en a une de trop.

          -
          Edité par julp 14 février 2023 à 11:49:52

          • Partager sur Facebook
          • Partager sur Twitter
            14 février 2023 à 11:52:38

            julp a écrit:

            Si on pourrait parfaitement joindre deux fois la même table mais dans ce cas elles doivent avoir des alias différents (et la condition de jointure serait différente).

            Là on a deux fois strictement la même jointure donc il y en a une de trop.

            -
            Edité par julp il y a moins de 30s


            On obtiendrait donc quelque chose du genre INNER JOIN article_froid AS A USING(artid) INNER JOIN article_froid AS AR USING(artid)
            • Partager sur Facebook
            • Partager sur Twitter
              14 février 2023 à 11:56:27

              Parce que USING(artid) n'est pas ambigu ? Il ne saura pas s'il doit prendre AR.artid, A.artid ou a.artid (et je doute encore en plus que le SGBD accepte l'alias a employé pour article et A pour article_froid)

              Et encore une fois, si la condition de jointure est la même, ça ne sert à rien de faire 2 fois une même jointure ...

              -
              Edité par julp 14 février 2023 à 12:00:55

              • Partager sur Facebook
              • Partager sur Twitter
                15 février 2023 à 20:40:07

                Bonjour, Merci d'indiquer un titre de sujet en rapport avec votre problématique, votre titre est trop vague, trop généraliste. Et utiliser l'outil adéquat pour insérer du code sur le forum. La modération. 

                Merci de colorer votre code à l'aide du bouton Code

                Les forums d'Openclassrooms disposent d'une fonctionnalité permettant de colorer et mettre en forme les codes source afin de les rendre plus lisibles et faciles à manipuler par les intervenants. Pour cela, il faut utiliser le bouton Code de l'éditeur, choisir un des langages proposés et coller votre code dans la zone prévue. Si vous utilisez l'éditeur de messages en mode Markdown, il faut utiliser les balises <pre class="brush: sql;">Votre code ici</pre>.

                Merci de modifier votre message d'origine en fonction.

                Mauvais titre

                Le titre est un élément important qui ne doit pas être négligé. N'oubliez pas cette règle simple : le titre idéal résume la question que vous allez poser en une petite phrase. Il doit permettre aux visiteurs de se repérer facilement dans le forum visité et d'identifier le sujet à sa seule lecture.

                Vous pouvez utiliser divers préfixes comme [Erreur], [MySQL], [Compatibilité], etc... Aussi, pensez à consulter les règles propres à chaque forum (visibles dans les topics épinglés en haut des sections).

                De plus, choisir un bon titre permet de rendre plus faciles les recherches des autres membres.

                Les titres de type "besoin d'aide" ou "problème" ne sont pas tolérés.

                Merci de modifier votre titre. Pour cela, éditez le premier message de votre sujet.

                (titre originel : Problème base de donnée)

                Liens conseillés

                • Partager sur Facebook
                • Partager sur Twitter

                Problème base de donnée

                × Après avoir cliqué sur "Répondre" vous serez invité à vous connecter pour que votre message soit publié.
                × Attention, ce sujet est très ancien. Le déterrer n'est pas forcément approprié. Nous te conseillons de créer un nouveau sujet pour poser ta question.
                • Editeur
                • Markdown