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

Bases de données Delphi Discussion :

Problème de nom de table


Sujet :

Bases de données Delphi

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

    Informations forums :
    Inscription : Décembre 2003
    Messages : 2
    Points : 2
    Points
    2
    Par défaut Problème de nom de table
    Bonjour,

    je dois reprendre une application sous access. Mon problème est le suivant : certaines tables ont un nom qui comportent le caractère ":", par exemple : "Liste : compartiment".

    J'utilise ADO avec Delphi.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    With AdoQuery1 do
    begin
      sql.clear;
      sql.add('select * from [Liste : compartiment]');
      connection:=adoconnection1;
      active:=True;
    ETC...
    J'obtiens alors l'erreur suivante : l'objet Parameter défini de manière incorrect. J'ai essayé de remplacer les : avec son caractère ASCII, même soucis.

    Avez-vous une idée ?

    Merci de votre aide.

    Cordialement

  2. #2
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    La seule solution est de renommer tes tables (ou d'en faire des vues) car les : sont considérés par les composants de base de données comme le passage d'un paramètre.

    De plus, des noms de table de ce style sont à bannir car ils posent plus de problèmes qu'autres choses (la preuve ).
    une des régles de bases pour les tables est de ne pas utiliser de caractères hors lettre, nombre et à la rigueur le _, tous autres caractères est à proscrire, car soit ils sont réservés par le moteur SQL lui même, soit il sont réservés par le langage de programmation.
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  3. #3
    Membre actif
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    265
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 265
    Points : 290
    Points
    290
    Par défaut
    Salut

    La pluspart des SGBD acceptent que tu mettes les noms de tables entre guillemets.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    With AdoQuery1 do
    begin
      sql.clear;
      sql.add('select * from "[Liste : compartiment]"');
      connection:=adoconnection1;
      active:=True;
    ETC...
    @+

Discussions similaires

  1. [WB10] Problème avec des noms de tables
    Par chuky dans le forum WebDev
    Réponses: 6
    Dernier message: 02/11/2007, 09h45
  2. problème de changement de nom de table
    Par sebac dans le forum Access
    Réponses: 2
    Dernier message: 16/07/2007, 10h06
  3. Problème nom de table
    Par arN34 dans le forum Informix
    Réponses: 2
    Dernier message: 11/08/2006, 21h55
  4. Problème de nom de table non conventionnel
    Par arN34 dans le forum Langage SQL
    Réponses: 1
    Dernier message: 11/08/2006, 14h00
  5. Problème Nom de table incorrecte
    Par Ricardo_Tubbs dans le forum ASP
    Réponses: 1
    Dernier message: 03/08/2006, 00h12

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