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

JDBC Java Discussion :

Probleme de requete sur une vue


Sujet :

JDBC Java

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2007
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Août 2007
    Messages : 33
    Points : 17
    Points
    17
    Par défaut Probleme de requete sur une vue
    Bonjour,

    J'ai un très gros soucis bloquant.
    J'ai une vue que j'arrive à interroger grâce à PL/SQL (en gros un select * from maVue depuis PL/SQL me retourne toutes les entrées)

    Le souci est que la même requête exécuté depuis java ne me retourne rien du tout.

    Et je ne vois pas du tout d'où cela vient (je tape bien sur la bonne base, j'ai pas d'erreur de requête etc...). Lorsque j'avais une table (en lieu et place de la vue) tout marchait correctement.

    Savez-vous d'où cela peut provenir ?

    J'ai entendu parler de droit mais je ne sais pas du tout comment voir/modifier les droits sur une vue.

    Merci d'avance pour votre aide

  2. #2
    Membre confirmé Avatar de djsnipe
    Inscrit en
    Mai 2008
    Messages
    440
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 440
    Points : 493
    Points
    493
    Par défaut
    Etrange en effet, pour JDBC, il n'y a pas de différence entre une vue et une table. Utilises tu bien le meme user/password entre ton accès JDBC et PL/SQL (SQLPLus je suppose ?)

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2007
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Août 2007
    Messages : 33
    Points : 17
    Points
    17
    Par défaut
    Les user/password sont bien les mêmes, pour l'instant je n'ai toujours pas de réponse à ce problème

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2007
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Août 2007
    Messages : 33
    Points : 17
    Points
    17
    Par défaut
    Pour info, la vue est créé grâce à d'autres tables
    Je sais pas si ça peut vous éclairer un peu plus

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2007
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Août 2007
    Messages : 33
    Points : 17
    Points
    17
    Par défaut
    Alors j'ai remarqué un truc :

    Je fais un

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CREATE OR REPLACE VIEW MAVUE AS SELECT * from uneTable;
    ça marche très bien

    Par contre en faisant la création de la vue avec des truc beaucoup plus compliqués (c'est à dire en fonction d'autres tables), ça ne marche plus

    Y-a-t-il des truc à ne pas faire lorsqu'on créé une vue à partir de tables ?

    PS : pour créer ma vue, 4 tables et 2 fonctions sont utilisés

  6. #6
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Points : 9 529
    Points
    9 529
    Billets dans le blog
    1
    Par défaut
    Il ne donne aucune erreur ?
    Peux-tu montrer la commande (exacte) de création de ta vue et la requête (exacte aussi) que tu fais ?

    a+
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2007
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Août 2007
    Messages : 33
    Points : 17
    Points
    17
    Par défaut
    Bon j'ai trouvé !

    j'avais dans ma clause WHERE un truc du style :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TO_DATE(SYSDATE) > TO_DATE(TMP.DATE_DEBUT)
    en PL/SQL ça passe (alors qu'on fait un TO_DATE d'une date)
    en Java il veut pas

  8. #8
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Points : 9 529
    Points
    9 529
    Billets dans le blog
    1
    Par défaut
    to_date est spécifique à Oracle
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  9. #9
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2007
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Août 2007
    Messages : 33
    Points : 17
    Points
    17
    Par défaut
    Ouaip

    C'est juste que lorsque je fais une requête sur ma vue depuis mon code Java, le fait que la vue soit construite de cette manière (c'est à dire avec un TO_DATE() d'une date dans la clause WHERE) pose un problème, et ma requête ne me retourne jamais rien

  10. #10
    Membre confirmé Avatar de djsnipe
    Inscrit en
    Mai 2008
    Messages
    440
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 440
    Points : 493
    Points
    493
    Par défaut
    Ca reste étonnant.
    En JDBC tu attaques une simple vue, construite de manière simple ou non, avec ou sans comparaison de dates dans sa déclaration, avec du code spécifique oracle ou non, mais une simple vue quand même. Je ne comprend pas qu'il puisse y avoir de différence entre un appel PL et un appel JDBC. Es-tu sur qu'en JDBC tu ne rajoutais pas des clauses where sur la vue invalides, ou avec de mauvais types pour les dates ?

  11. #11
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2007
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Août 2007
    Messages : 33
    Points : 17
    Points
    17
    Par défaut
    Etant donné que j'avais pas mal de problème pour accéder à cette vue, j'ai fait une requête simple depuis Java :

    Et il ne me retournait rien, alors qu'en PL/SQL il me retournait correctement les données

    J'avoue que je n'y comprends pas grand chose non plus

Discussions similaires

  1. faire des requetes sur une vue
    Par lorie dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 19/05/2011, 11h28
  2. Probleme de performance sur une vue
    Par nomissamoht dans le forum Oracle
    Réponses: 1
    Dernier message: 06/03/2009, 14h51
  3. [SQL] Probleme de requete sur une même table
    Par LP-mpascolo dans le forum Langage SQL
    Réponses: 3
    Dernier message: 30/01/2008, 14h02
  4. Grosse Requete ou Requete sur une vue ?
    Par TangoZoulou dans le forum Langage SQL
    Réponses: 15
    Dernier message: 20/07/2007, 09h52
  5. Réponses: 3
    Dernier message: 23/03/2007, 22h26

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