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

PHP & Base de données Discussion :

mot réservé dans un nom de champ [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 3
    Points : 2
    Points
    2
    Par défaut mot réservé dans un nom de champ
    Dans une de mes bases de données, j'ai un champ que j'avais de façon étourdie/un peu risquée nommé 'for' (abréviation de 'force').

    D'un autre côté, toute l'utilisation que j'en avais fait jusqu'ici ne m'avait poser aucun problème, en particulier je n'ai aucun pb à récupérer le contenu du champ avec une requête.

    Le problème s'est posé hier lorsque j'ai voulu au contraire ECRIRE une valeur dans le champ (syntax error).

    Cela va un peu plus loin, puisque n'imoprte quel mot commençant par 'for' engendre la même erreur ('force' en entier pose le même problème).

    Comme je préfèrerais ne pas avoir à passer en revue tous mes programmes pour modifier le nom du champ, est-ce que qqun a un truc pour forcer une requête INSERT ou UPGRADE à accepter un nom de champ commençant par for ??

  2. #2
    Membre éclairé Avatar de nako
    Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Août 2003
    Messages
    577
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Août 2003
    Messages : 577
    Points : 663
    Points
    663
    Par défaut
    Salut, peux-tu nous écrire ta requête ?
    Sinon, essaie de mettre des ` entre le nom qui pose problème `for`.

    Et pour être sur et certain, si tu as PHPMyAdmin par exemple, essaie d'insérer une ligne directement en faisant Insérer dans l'interface.
    PHPMyAdmin réécrit la requête après exécution, commeça, tu verras la bonne syntaxe.
    a+

  3. #3
    Membre éprouvé
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    1 012
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 1 012
    Points : 1 093
    Points
    1 093
    Par défaut
    que tu utilises for ne me paraît pas très judicieux en effet
    mais que cela plante avec force m'étonne, il doit y avoir un autre problème

  4. #4
    Candidat au Club
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    Dans l'ordre,
    la requête :
    $mettre=sprintf("INSERT INTO persos (nomP,mf,IdR,IdE,tai,mass, agi, luc, vol, sous,for) VALUES ( %s, %s, %s, %s,'$taille','$masse','$agilete','$lucidite','$volonte','10000','$forces') ",
    cricrac($_POST['nomP']),cricrac($mf),cricrac($_POST['race']),cricrac($_POST['ecole'])
    );

    Avec PHPMyAdmin : il fait l'insertion en mettant les noms de champs entre '. Quand j'essaie de mettre 'for', avec la requête ci-dessus dans le programme, erreur de syntaxe.

    J'ai revérifié la requête ci-dessus:
    - donc, avec le nom 'for', erreur;
    - avec le nom for, erreur;
    - avec le nom force, erreur;
    - avec le nom str, pas de problème l'insertion s'exécute parfaitement.

  5. #5
    Membre actif Avatar de leodi
    Homme Profil pro
    Directeur technique
    Inscrit en
    Février 2004
    Messages
    172
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Février 2004
    Messages : 172
    Points : 224
    Points
    224
    Par défaut
    Esseye en mettant `for` et `force`, j'ai eut un problème similaire et en utilisant ces "guillemets ?" ca a fonctionné.

    Edit : déjà proposé par quelqu'un (nako), ce sont des `$$` et pas des '$$' fait bien la différence.

  6. #6
    Candidat au Club
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    Leodi, merci beaucoup.

    Dire que cela fait des mois que je lis des références et explications diverses et que je n'avais jamais remarqué la différence.

    Ca marche donc maintenant avec le nom de champ entre ` `.

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

Discussions similaires

  1. Variable dans un nom de champ
    Par zorgov dans le forum SAP Crystal Reports
    Réponses: 1
    Dernier message: 03/12/2008, 21h12
  2. Réponses: 1
    Dernier message: 20/08/2008, 15h05
  3. Imprimer tous les fichiers avec un mot spécifié dans le nom
    Par cyber-kaiser dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 11/06/2007, 13h35
  4. Espace dans le nom du champs (PB)
    Par crovette51101 dans le forum Oracle
    Réponses: 2
    Dernier message: 08/11/2006, 13h17
  5. mot clef sql pour nom de champ
    Par bobinou007 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 12/10/2004, 13h21

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