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 :

[D3+BDE+Firebird] casse tête de Dialect


Sujet :

Bases de données Delphi

  1. #1
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 031
    Points : 40 930
    Points
    40 930
    Billets dans le blog
    62
    Par défaut [D3+BDE+Firebird] casse tête de Dialect
    Bonjour,

    j'ai d'anciennes applications D3 que je dois encore maintenir. Celles-ci à l'époque, utilisaient une base de Données Interbase 4.5 qui a migré ensuite en 5.4 puis 6 afin d'aboutir en Firebird 2.1 ceci pour expliquer :
    - le contexte
    - le dialect de la base resté à 1

    j'ai été obligé de créer une nouvelle table dans cette base
    pour tester : mon poste utilise firebird 2.5

    Avec une nouvelle application ou directement avec un GUI Firebird (flamerobin) je n'ai aucun soucis de connexion à cette table mais avec l'ancienne application que je dois modifier je reçois un message abscons m'indiquant que le client en dialect 1 ne supporte pas BIGINT ! alors qu'il n'y a aucun BIGINT dans la table

    du coup je n'arrive pas à trouver l'origine du problème BDE, informations dans TDatabase, autres ?
    Quelqu'un aurait-il déjà eu ce problème (c'est la deuxième fois que cela m'arrive sur cette semaine! j'ai contourné la première mais sur cette deuxième je séche )
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  2. #2
    Membre émérite Avatar de edam
    Homme Profil pro
    Développeur Delphi/c++/Omnis
    Inscrit en
    Décembre 2003
    Messages
    1 894
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Développeur Delphi/c++/Omnis
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 894
    Points : 2 771
    Points
    2 771
    Par défaut
    salut
    je crois que c'est normale integer fb2.5(64bit) pour D3 (16bits) le vois comme bigint
    PAS DE DESTIN, C'EST CE QUE NOUS FAISONS

  3. #3
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 031
    Points : 40 930
    Points
    40 930
    Billets dans le blog
    62
    Par défaut
    Merci de la réponse mais avec une autre application test cela fonctionne donc ce n'est pas une question de bits de l'OS (d'ailleurs D3 fait des 32bits pas des 16)
    de plus j'ai omis de le préciser le poste sur lequel je fais ce travail est un 32 bits (donc firebird 2.5 32bits)

    En cernant mieux, il s'avère que l'ouverture en table (TTable) se passe correctement, c'est une requête (TQuery) qui me pose ce souci
    en réduisant les colonnes à récupérer (donc pas de SELECT * mais un SELECT précis) j'ai réduit le problème à la colonne qui était en DECIMAL(18,0)

    je vais la passer en INTEGER simple ou en NUMERIC(?,0) pour voir ce qui va se passer. La suite au prochain épisode avec je l'espère un Résolu
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  4. #4
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 447
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 13 447
    Points : 24 849
    Points
    24 849
    Par défaut
    NUMERIC(9, 0) ou alors DECIMAL(14,1) pour le forcer en Double, tu auras ainsi des nombres plus grand si le besoin se fait sentir !

    C'est pareil sur ORACLE, cela retourne parfois un BIGINT sans trop raison apparente
    Une Colonne NUMBER(9) alimenté en PL/SQL par une SEQUENCE non plafonné, et cela produit du ftLargeInt car il utilise le type la séquence et non le type du champ recevant la valeur
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  5. #5
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 031
    Points : 40 930
    Points
    40 930
    Billets dans le blog
    62
    Par défaut
    Citation Envoyé par ShaiLeTroll Voir le message
    NUMERIC(9, 0)
    qui n'est en fait qu'un integer passe
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DECIMAL(14,1) pour le forcer en Double,
    ne passe pas étrangement, alors que j'ai du NUMERIC(15,2) ou NUMERIC(15,4) dans la base d'origine

    je pense que c'est du au changement de DIALECT et de l'interprétation qui en est faite alors par Firebird, j’essaierai de voir ça ce week-end en fouillant du coté des tables systèmes. Comme Integer couvrira largement mes besoins je vais en rester là. Etrange quand même que le TTable accepte et pas le TQuery, que même si le DIALECT est forcé dans les paramètres de TDatabase (SQLDIALECT=3) ce ne soit pas pris en compte, mais bon il s'agit de D3

    mon problème est mais je vais laisser ouverte cette discussion le temps de faire un test avec D7, puis d2010 disponibles sur ce poste et pour cette fouille table système si j'ai le courage
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

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

Discussions similaires

  1. [BDE][FIREBIRD][Win8] impossible de se connecter à la base de données
    Par SergioMaster dans le forum Bases de données
    Réponses: 9
    Dernier message: 20/05/2015, 13h37
  2. [XL-2003] Case-tête lancement Userform sur feuille protégée
    Par FrankCF dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 06/08/2011, 21h57
  3. Firebird - BDE - Win XP/win2000
    Par dd_garion dans le forum Connexion aux bases de données
    Réponses: 3
    Dernier message: 21/09/2006, 08h21
  4. XMLRAD, Firebird et SQL DIALECT
    Par tekilx dans le forum XMLRAD
    Réponses: 1
    Dernier message: 15/05/2006, 14h18
  5. [Firebird][Optimisation]Plus lent que le BDE!
    Par vincentj dans le forum Débuter
    Réponses: 3
    Dernier message: 07/02/2005, 15h48

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