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 requêtage des champs LVARCHAR sous Informix


Sujet :

Bases de données Delphi

  1. #1
    Membre confirmé Avatar de WebPac
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 947
    Points : 512
    Points
    512
    Par défaut Problème de requêtage des champs LVARCHAR sous Informix
    Bonjour,

    je n'ai pas l'habitude de faire des sujet cross-forum mais mon problème est à cheval entre Delphi et Informix et je n'ai pas eu de réponse sur le forum d'Informix; c'est pourquoi je me permets de ré-écrire mon problème ici afin d'arriver à trouver une solution à mon problème.

    Je développe un logiciel fait en Delphi XE2 qui se connecte à des bases de données dont parfois Informix.
    J'ai un soucis quand je dois requêter une table possédant des champs du type LVARCHAR.

    Si je fais une requête basique
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT MON_CHAMP FROM MA_TABLE
    J'obtiens le message d'erreur
    Unknown error message 0.
    J'ai essayé ensuite en faisant différents CAST :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT CAST(MON_CHAMP AS VARCHAR(255)) FROM MA_TABLE
    La requête s'ouvre mais je n'obtiens que les 255 premiers caractères.
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT CAST(MON_CHAMP AS VARCHAR(256)) FROM MA_TABLE
    J'obtiens le message d'erreur
    Maximum varchar size has been exceeded.
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT CAST(MON_CHAMP AS TEXT) FROM MA_TABLE
    J'obtiens le message d'erreur
    No cast from lvarchar to text.
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT CAST(MON_CHAMP AS CLOB) FROM MA_TABLE
    J'obtiens le message d'erreur
    User Defined Routine error.
    Je ne suis pas spécialiste d'informix, je n'ai plus d'idées et je ne vois pas comment arriver à remonter les valeurs du champs sans qu'elles ne soient tronquées.

    Merci par avance pour votre aide.

  2. #2
    Modérateur
    Avatar de tourlourou
    Homme Profil pro
    Biologiste ; Progr(amateur)
    Inscrit en
    Mars 2005
    Messages
    3 858
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Biologiste ; Progr(amateur)

    Informations forums :
    Inscription : Mars 2005
    Messages : 3 858
    Points : 11 301
    Points
    11 301
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Lu ici :
    Important: You cannot retrieve or store smart large objects (CLOB or BLOB data types) from or to an lvarchar host variable.
    Et :
    To use the external format of an opaque type in an SQL statement, the opaque data type must have input and output support functions defined. When the client application uses an lvarchar host variable to transfer data to or from an opaque-type column, the database server invokes the following support functions of the opaque data type:

    The input support function describes how to transfer the opaque-type data from the lvarchar host variable into the opaque-type column.

    The database server invokes the input support function for operations such as INSERT and UPDATE statements that send the external format of an opaque type to the database server.
    The output support function describes how to transfer the opaque-type data from the opaque-type column to the lvarchar host variable.

    The database server invokes the output support function for operations such as SELECT and FETCH statements that send the external format of an opaque type to the client application.
    avec le support de fonctions dédiées.
    Est-ce une solution de faire des fonctions de CAST personnelles vers un format personnel ? Si c'est le cas, il est dommage que ce ne soit pas implémenté vers un format tel que Memo ou autre. Ceci dépend-il des composants d'accès ou du driver ?
    Delphi 5 Pro - Delphi 11.3 Alexandria Community Edition - CodeTyphon 6.90 sous Windows 10 ; CT 6.40 sous Ubuntu 18.04 (VM)
    . Ignorer la FAQ Delphi et les Cours et Tutoriels Delphi nuit gravement à notre code !

  3. #3
    Membre confirmé Avatar de WebPac
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 947
    Points : 512
    Points
    512
    Par défaut
    Salut,

    j'ai tenté de faire des CAST dans la requête SQL car le type LVARCHAR d'Informix remonte une erreur lors de l'ouverture de la requête, mais je ne sais pas du tout si c'est la bonne approche pour avoir une solution au problème.
    S'il faut le faire différemment, je prends aussi.

    D'après ta citation, le problème viendrait du fait que le type LVARCHAR est un type opaque, c'est-à-dire spécifique à Informix et qu'il n'est pas pris en charge par les composants dbExpress ?
    Et pour arriver à remonter ses valeurs, il faudrait utiliser des fonctions qui supportent ces types opaques, malheureusement les fonctions qui les supportent ne sont pas des fonctions SQL, mais du IBM Informix ESQL/C.
    Après recherche, c'est une librairie de fonctions faite par IBM pour des développeurs C.

    Mon soucis est que je développais à l'époque avec Delphi 7, j'utilisais une dll luxena couplée aux composants dbExpress et ça fonctionnait. Depuis que je suis passé en Delphi XE2 avec le support de l'unicode, je ne peux plus utiliser les composants Luxena car ils ne sont plus maintenus et n'ont pas étés migrés dans la nouvelle version des composants dbExpress (v4 pour Delphi XE2 de mémoire) et j'espère pouvoir trouver une solution sans devoir inclure du code spécifique utilisant du C pour quelques types particuliers de champs d'Informix dans mon application alors qu'elle n'est pas développée principalement pour Informix (elle génère du SQL générique et sait se connecter à un ensemble de type de bases différent).

  4. #4
    Expert confirmé
    Avatar de Ph. B.
    Homme Profil pro
    Freelance
    Inscrit en
    Avril 2002
    Messages
    1 784
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2002
    Messages : 1 784
    Points : 5 915
    Points
    5 915
    Par défaut
    Bonjour,
    Citation Envoyé par WebPac Voir le message
    j'ai tenté de faire des CAST dans la requête SQL car le type LVARCHAR d'Informix remonte une erreur lors de l'ouverture de la requête, mais je ne sais pas du tout si c'est la bonne approche pour avoir une solution au problème.
    Malgré ses limitations, je crains que ce ne soit la bonne approche...
    Apparemment, c'est un bug ouvert chez Embarcadero depuis le 15/10/2010 (Delphi XE), mais non traité :
    http://qc.embarcadero.com/wc/qcmain.aspx?d=88986

    Citation Envoyé par WebPac Voir le message
    S'il faut le faire différemment, je prends aussi.
    Via ADO ? ODBC ?
    Philippe.

  5. #5
    Membre confirmé Avatar de WebPac
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 947
    Points : 512
    Points
    512
    Par défaut
    J'ai vu le bug ouvert chez Embarcadero, j'aurais dû remonter le lien j'ai oublié.

    Il a été demandé au client de passer en ODBC, je n'ai pas de retour, ça veut très probablement dire que ça fonctionne ainsi.

    Je marque donc en résolu.

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

Discussions similaires

  1. Problème de requêtage des champs LVARCHAR
    Par WebPac dans le forum Informix
    Réponses: 2
    Dernier message: 06/06/2014, 16h17
  2. Probléme d'affichage des champs des tables sous VS
    Par ikramB dans le forum VB.NET
    Réponses: 0
    Dernier message: 02/11/2010, 13h05
  3. problème au niveau des champs
    Par mmanta1 dans le forum IHM
    Réponses: 4
    Dernier message: 14/06/2007, 15h01
  4. Problème de parcours des champs dans l'ordre.
    Par jyms2006 dans le forum Access
    Réponses: 1
    Dernier message: 19/04/2006, 11h08
  5. Delphi - Base donnée Paradox, problème de nom des champs
    Par mjp dans le forum Bases de données
    Réponses: 1
    Dernier message: 02/01/2005, 21h10

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