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

Requêtes MySQL Discussion :

Problème requête après migration [MySQL-8.0]


Sujet :

Requêtes MySQL

  1. #1
    Candidat au Club
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2024
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Landes (Aquitaine)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Janvier 2024
    Messages : 2
    Points : 3
    Points
    3
    Par défaut Problème requête après migration
    Bonjour,
    ayant procédé a un upgrade de mysql (5.7 vers 8.0) et utilisant un code assez vieux, j'ai certaines requêtes qui ne fonctionne plus.
    J'ai réussis a en modifier la plupart pour débug mais pour celle ci je sèche :

    Citation Envoyé par l'erreur
    ChildLoop: AsyncSQL: query failed: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'window+0, pos, count, vnum, transmutation, socket0, socket1, socket2, attrtype0,' at line 1 (query: SELECT id, window+0, pos, count, vnum, transmutation, socket0, socket1, socket2, attrtype0, attrvalue0, attrtype1, attrvalue1, attrtype2, attrvalue2, attrtype3, attrvalue3, attrtype4, attrvalue4, attrtype5, attrvalue5, attrtype6, attrvalue6, sealbind FROM item WHERE owner_id=117 AND (window < 3 or window = 5 or window = 6 or window = 7 or window = 8)

    En faisant plusieurs test directement depuis la console je me suis rendu compte que le problème était liée a la colonne "window", qui est de type enum.

    Cette requette fonctionnait bien sur mysql57, j'avoue être perdu.

    Si une âme charitable passe par ici...

    Cordialement, Fabien

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 198
    Points : 12 774
    Points
    12 774
    Par défaut
    Bonjour,
    Window est une fonction de MySQL, donc il ne peut pas être utilisé comme nom de colonne, à moins de le mettre entre guillemets.
    Visiblement cette fonction est arrivée après la version 5.7, ce qui explique que la requête fonctionnait avant la migration.

    Tatayo.

  3. #3
    Candidat au Club
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2024
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Landes (Aquitaine)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Janvier 2024
    Messages : 2
    Points : 3
    Points
    3
    Par défaut
    Bonjour,

    En effet, depuis mysql 8.0, windows est un mot clé réservé.
    la solution consiste donc a reprendre le code en ajoutant les guillemets spéciaux backticks (``).

    Merci tatayo pour cette mise au clair qui m'avait échapé.

    Sujet résolu.

    Cdt Fabien

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 136
    Points : 38 910
    Points
    38 910
    Billets dans le blog
    9
    Par défaut
    Autre solution : choisir un préfixe ou un suffixe différent pour chaque table et associer ce préfixe ou ce suffixe à chaque colonne de la table concernée, ainsi, on ne tombe jamais sur un mot réservé SQL et les études d'impact sont grandement facilitées

    Exemple, pour un MCD classique clients, commandes, lignes de commandes et articles, dans lequel les lignes de commandes, entité-type faible de la commande, sont identifiées relativement à la commande, on modélise ceci :

    [CL_CLIENT] 1,n --- (emettre) --- 1,1 [CO_COMMANDE] 1,n --- (contenir) --- 1,1(R) [LC_LIGNE_CDE] 1,1 --- concerner --- 0,n [AR_ARTICLE]

    Ce qui donnera les tables suivantes (PK soulignées, FK suffixées par #)

    CL_CLIENT(CL_ident, CL_numero, CL_date_creat, CL_nom...)
    CO_COMMANDE(CO_ident, CO_numero, CO_date, CL_ident#...)
    AR_ARTICLE(AR_ident, AR_reference, AR_designation...)
    LC_LIGNE_CDE(CO_ident#, LC_sequence, LC_quantite, AR_ident#...)

    Non seulement on n'a pas de mot réservé SQL, donc pas besoin de s'embêter avec des quotes inverses (MySQL) ou doubles quotes (autres SGBD), mais aussi on sait d'emblée de quelle table vient telle colonne, notamment les FK.
    Très pratique à l'usage

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

Discussions similaires

  1. requte md5 mysql
    Par jcaspar dans le forum Requêtes
    Réponses: 1
    Dernier message: 13/08/2007, 16h06
  2. Probleme C++Builder et Mysql
    Par noname dans le forum C++Builder
    Réponses: 3
    Dernier message: 20/06/2002, 13h40
  3. connection a une BDD MySql
    Par delire8 dans le forum MFC
    Réponses: 7
    Dernier message: 19/06/2002, 18h18
  4. [Kylix] Pb connection à Mysql
    Par Anonymous dans le forum EDI
    Réponses: 3
    Dernier message: 25/04/2002, 15h26

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