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

Développement Web en Java Discussion :

Pb avec sysdate en EJBQL


Sujet :

Développement Web en Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Novembre 2007
    Messages
    106
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 106
    Par défaut Pb avec sysdate en EJBQL
    Bonjour,
    J'ai un probleme avec sysdate dans une requete en ejb ql.

    ma requete est simple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT OBJECT(B) FROM table1 B1, table2 B2
            WHERE B.dacre BETWEEN B2.ddeb AND B2.dfin 
            AND sysdate BETWEEN B2.ddeb and B2.dfin
    à la compilation, il ne reconnait pas sysdate: il m'affiche cette erreur :

    the path expression/Identifier sysdate starts with an identifier: sysdate . The identifier sysdate , which can be either a range variable identifier or a collection member identifier, is required to be declared in the FROM clause of its query or in the FROM clause of a parent query

    Est ce que quelqu'un a une idée ?

    Merci

  2. #2
    Membre chevronné
    Homme Profil pro
    Développeur Java
    Inscrit en
    Avril 2004
    Messages
    265
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Avril 2004
    Messages : 265
    Par défaut
    Salut,
    sysdate n'est pas un mot clé ejbql.
    Je ferais un truc de ce style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT OBJECT(B) FROM table1 B1, table2 B2
            WHERE B.dacre BETWEEN B2.ddeb AND B2.dfin 
            AND ?1 BETWEEN B2.ddeb and B2.dfin
    puis
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    setParameter(1,new Date(), TemporalType.DATE)

  3. #3
    Membre confirmé
    Inscrit en
    Novembre 2007
    Messages
    106
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 106
    Par défaut
    Merci pour votre reponse,
    J'ai ma requete dans un fichier ejb-jar.xml exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    <query-method>
              <method-name>nameMethode</method-name>
              <method-params>
                <method-param>???????</method-param>
              </method-params>
            </query-method>
            <ejb-ql><![CDATA[
                    SELECT OBJECT(B) FROM table1 B1, table2 B2
            WHERE B.dacre BETWEEN B2.ddeb AND B2.dfin 
            AND sysdate BETWEEN B2.ddeb and B2.dfin
            ]]></ejb-ql>
           </query>
    comment ajouter le parametre sysdate dans la methode ?

    Merci

  4. #4
    Membre chevronné
    Homme Profil pro
    Développeur Java
    Inscrit en
    Avril 2004
    Messages
    265
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Avril 2004
    Messages : 265
    Par défaut
    En faisant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    <query-method>
              <method-name>nameMethode</method-name>
              <method-params>
                <method-param>???????</method-param>
              </method-params>
            </query-method>
            <ejb-ql><![CDATA[
                    SELECT OBJECT(B) FROM table1 B1, table2 B2
            WHERE B.dacre BETWEEN B2.ddeb AND B2.dfin 
            AND ?1 BETWEEN B2.ddeb and B2.dfin
            ]]></ejb-ql>
           </query>
    A noter que cette requête (sauf si c'est une version simplifiée pour l'exemple) ne doit pas fonctionner ne toutes façons :
    • Pas de jointure entre table1 et table2
    • L'alias B ne correspond à rien (il n'y a que B1 et B2)

  5. #5
    Membre confirmé
    Inscrit en
    Novembre 2007
    Messages
    106
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 106
    Par défaut
    oui c'est une requete simplifiée.
    c'est B1 a la place du B

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    <query-method>
              <method-name>nameMethode</method-name>
              <method-params>
                <method-param>???????</method-param>
              </method-params>
            </query-method>
            <ejb-ql><![CDATA[
                    SELECT OBJECT(B1) FROM table1 B1, table2 B2
            WHERE B1.dacre BETWEEN B2.ddeb AND B2.dfin 
            AND ?1 BETWEEN B2.ddeb and B2.dfin
            ]]></ejb-ql>
           </query>

Discussions similaires

  1. Alias dynamique avec sysdate - n days dedans
    Par lbar012001 dans le forum PL/SQL
    Réponses: 5
    Dernier message: 12/03/2014, 15h39
  2. [11g] Fermeture socket sur requete avec sysdate
    Par Francky8 dans le forum Administration
    Réponses: 1
    Dernier message: 03/02/2014, 15h59
  3. Problème dans ma requête avec sysdate
    Par jacko842 dans le forum SQL
    Réponses: 9
    Dernier message: 28/08/2012, 11h01
  4. comparaison avec SYSDATE
    Par ishika83 dans le forum SQL
    Réponses: 6
    Dernier message: 03/09/2009, 13h27
  5. spool avec sysdate
    Par potimarara dans le forum SQL
    Réponses: 4
    Dernier message: 24/10/2007, 14h24

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