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 :

DBExpress, applyupdate et Oracle


Sujet :

Bases de données Delphi

  1. #1
    brt
    brt est déconnecté
    Candidat au Club
    Inscrit en
    Mai 2004
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 5
    Points : 2
    Points
    2
    Par défaut DBExpress, applyupdate et Oracle
    Bonjour,

    j'ai créer une application sous delphi qui permettait d'enregistrer des donées dans une table Interbase.Cette page était composé d'un DBGrid pour l'affichage et de DBEdit reliés à mes champ dans ma base. L'utilisateur apres modif apuyait sur un bouton et je faisait un ApplyUpdates.Tout fonctionnait normalement.

    Je suis passé en Oracle et j'ai donc modifié les propriétés de ma connexion DBexpress. J'arrive à lire les données de ma table et enregister des données quand il n'y a pas de dates.
    Dès qu'il y a une date à enregistrer Oracle me met une erreur:
    ORA-01722:invalid number
    Je sais que ma date à un mauvais format, mais si je force la date au format Oracle 'yyyy-MM-dd hh:mm:ss' le clientdataset me le refuse avec 'format de date non valide'. comment faire???

    Merci d'avance.

  2. #2
    Membre à l'essai
    Inscrit en
    Décembre 2002
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Décembre 2002
    Messages : 13
    Points : 12
    Points
    12
    Par défaut
    Bonjour,

    J'ai également eu ce problème avec les paramètres d'un TSQLQuery finlament en convertissant ma date en string dans le code sa à fonctionné.

    J'ai donc fait comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    qry.parambyname('date').Value := DateToStr(LaDate);
    Il faudrait donc que tu transformes ta dates en texte avec de faire l'applyupdate.

  3. #3
    brt
    brt est déconnecté
    Candidat au Club
    Inscrit en
    Mai 2004
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 5
    Points : 2
    Points
    2
    Par défaut
    merci pour ta réponse

    mais l'avantage d'un applyupdate (dans un clientdataset) par rapport à une création de requete en code c'est de pouvoir créer , supprimer, ou modifier des enregistrements
    Si je passe avec des requete SQL, je devrais avoir 3 requetes différentes et comment updater un enregistrement si l'utilisateur modifie la clefs primaire??

  4. #4
    brt
    brt est déconnecté
    Candidat au Club
    Inscrit en
    Mai 2004
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 5
    Points : 2
    Points
    2
    Par défaut
    j'ai oublié le principal!

    le problème c'est que mon clientdataset est relié a ma base et qu'il attend un format date je ne peux donc pas transformer ma date en string

  5. #5
    Membre éprouvé Avatar de star
    Homme Profil pro
    .
    Inscrit en
    Février 2004
    Messages
    842
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Corée Du Nord

    Informations professionnelles :
    Activité : .

    Informations forums :
    Inscription : Février 2004
    Messages : 842
    Points : 983
    Points
    983
    Par défaut
    je force la date au format Oracle 'yyyy-MM-dd hh:mm:ss'
    Comment procèdes-tu pour indiquer le format de date ?
    .
    Diviser c'est régner : United we stand, Divided we fall
    .

  6. #6
    brt
    brt est déconnecté
    Candidat au Club
    Inscrit en
    Mai 2004
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 5
    Points : 2
    Points
    2
    Par défaut
    Pour l'instant je faisait:

    DBEdit3.Text:=formatdatetime('yyyy-MM-dd hh:mm:ss',datedebut);

  7. #7
    Membre éprouvé Avatar de star
    Homme Profil pro
    .
    Inscrit en
    Février 2004
    Messages
    842
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Corée Du Nord

    Informations professionnelles :
    Activité : .

    Informations forums :
    Inscription : Février 2004
    Messages : 842
    Points : 983
    Points
    983
    Par défaut
    T'es-tu assuré que ce format est celui par défaut de la base Oracle ?
    As-tu essayé d'autres formats comme 'dd/mm/yyyy hh24:mi:ss' ?
    .
    Diviser c'est régner : United we stand, Divided we fall
    .

  8. #8
    brt
    brt est déconnecté
    Candidat au Club
    Inscrit en
    Mai 2004
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 5
    Points : 2
    Points
    2
    Par défaut
    Plutôt que de batailler pour trouver la solution,
    j'ai remplacé tout les DBEdits par des Edits que je gère moi même au niveau de l'affichage.
    Je construit mes requetes en code (mes dates sont des string et je n'ai plus de problèmes comme le disait tiennos)
    Ainsi je reste au niveau de la QuerySQL et je ne descend pas au ClientDataSet (qui posait des problèmes de format de date).

    Merci à vous pour l'aide que vous m'avez fournis

    A+

    brt

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

Discussions similaires

  1. [d2007] DBExpress + Oracle + ApplyUpdates
    Par vedge2000 dans le forum Bases de données
    Réponses: 2
    Dernier message: 14/11/2011, 22h34
  2. [MySQL][DbExpress][D7] clientdataset.applyupdates
    Par nanomag dans le forum Bases de données
    Réponses: 2
    Dernier message: 17/06/2004, 16h48
  3. Dbexpress et Oracle
    Par denza1 dans le forum Bases de données
    Réponses: 5
    Dernier message: 11/06/2004, 01h06
  4. DBExpress et Oracle Recupération des params de TSQLDataSet
    Par ThierryD dans le forum Bases de données
    Réponses: 2
    Dernier message: 10/06/2004, 19h30
  5. [Kylix] kylix + dbexpress pour oracle!!
    Par RezzA dans le forum EDI
    Réponses: 6
    Dernier message: 14/01/2003, 18h33

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