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 :

Firedac, definition DataType sur requête SQL


Sujet :

Bases de données Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2012
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

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

    Informations forums :
    Inscription : Janvier 2012
    Messages : 114
    Par défaut Firedac, definition DataType sur requête SQL
    Bonjour,

    J'utilise un TFDQuery avec une requête SELECT. Comment sont définies les datatypes des champs au retour de la requête ?

    sur une base Oracle je fait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Query.SQL.Text := 'SELECT champ_clob FROM matable';
    En retour, j'ai Query.FieldByName('champ_clob').DataType = ftWideMemo.

    Comment est définit ce format ? Est-il possible de forcer à ftOraClob par exemple ?

  2. #2
    Expert confirmé
    Avatar de anapurna
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    3 496
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 496
    Par défaut
    salut

    ce format est définit par le champs lui même c'est à dire l'information que lui donne la base de donnée sur le champs pointé lorsque tu
    tu ajoute tes champs dans un TQuery

    J'ai tendance a me servir de cette proprieté comme ceci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
       if (DS.Fields[i].DataType in [ftFloat,ftCurrency, ftBCD, ftFMTBcd]) then
    j'ai tres peu confiance au datatype généré de façon automatique donc je préfère mettre toutes les valeur de même type ensemble

  3. #3
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 706
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 706
    Billets dans le blog
    65
    Par défaut
    Bonjour,

    En retour, j'ai Query.FieldByName('champ_clob').DataType = ftWideMemo. Comment est défini ce format ?
    via le dictionnaire de la BDD je pense que le traitement se fait dans une des unités de Firedac (FireDAC.Stan.Intf ?)
    Est-il possible de forcer à ftOraClob par exemple ?
    oui il est possible de forcer en utilisant les maprules (FormatOptions.MapRules FormatOptions.OwnMapRules).
    Sachant que ces derniers sont "multi-niveaux" : niveau de la base, de la query ou table, d'ensemble de champs ou d'un champ particulier

    par contre je ne vois pas de type ftOraCBlob (c'est un type inventé ?) , uniquement
    dtBlob, dtMemo, dtWideMemo, dtXML, // value blobs
    dtHBlob, dtHMemo, dtWideHMemo, // handle blobs
    Ne connaissant pas Oracle j'ai été voir ce qu'était un CBlob (moi je connais Blob Text et Blob Binary)
    A CLOB (Character Large Object) is an Oracle data type that can hold up to 4 GB of data. CLOBs are handy for storing text.
    je dirai donc que cela correspondrait plutôt à un dtMemo et NCBLOB à un dtWideMemo mais comme Delphi est Unicode je comprends (en théorie) pourquoi dtWideMemo soit le format proposé

  4. #4
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2012
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

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

    Informations forums :
    Inscription : Janvier 2012
    Messages : 114
    Par défaut
    Dans l'unité DB
    TFieldType = (ftUnknown, ftString, ftSmallint, ftInteger, ftWord, // 0..4
    ftBoolean, ftFloat, ftCurrency, ftBCD, ftDate, ftTime, ftDateTime, // 5..11
    ftBytes, ftVarBytes, ftAutoInc, ftBlob, ftMemo, ftGraphic, ftFmtMemo, // 12..18
    ftParadoxOle, ftDBaseOle, ftTypedBinary, ftCursor, ftFixedChar, ftWideString, // 19..24
    ftLargeint, ftADT, ftArray, ftReference, ftDataSet, ftOraBlob, ftOraClob, // 25..31
    ftVariant, ftInterface, ftIDispatch, ftGuid, ftTimeStamp, ftFMTBcd, // 32..37
    ftFixedWideChar, ftWideMemo, ftOraTimeStamp, ftOraInterval, // 38..41
    ftLongWord, ftShortint, ftByte, ftExtended, ftConnection, ftParams, ftStream, //42..48
    ftTimeStampOffset, ftObject, ftSingle); //49..51
    Merci de vos réponses, je vais regarder du côté des MapRules.

  5. #5
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 706
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 706
    Billets dans le blog
    65
    Par défaut
    Dans l'unité DB ok mais pas dans l'unité Firedac or je pense que les maprules n'utilise que les types de Firedac , à vérifier.
    En tout cas le test rapide que j'ai pu faire ne le propose pas

  6. #6
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2012
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

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

    Informations forums :
    Inscription : Janvier 2012
    Messages : 114
    Par défaut
    Effectivement, TFDMapRule utilise FireDAC.Stan.Intf.TFDDataType, et TField utilise DB.TFieldDataType.

    Je n'ai pas encore put faire des tests, je vous tient au courant.

Discussions similaires

  1. Tests Fonctionnels sur requête SQL
    Par The Vandals dans le forum Langage SQL
    Réponses: 16
    Dernier message: 09/03/2010, 21h03
  2. [SQL] Question sur requête SQL
    Par Cheeper dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 27/06/2007, 18h56
  3. [SQL-Server] Problème d'accents sur requête SQL, de php à SQLServer
    Par pontos dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 05/04/2007, 15h58
  4. aide sur requête sql
    Par Vodkha dans le forum Langage SQL
    Réponses: 9
    Dernier message: 30/08/2005, 18h53
  5. Aide sur Requête SQL
    Par devdev dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 11/05/2005, 13h33

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