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

JPA Java Discussion :

JPA J2SE Persistence.xml


Sujet :

JPA Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Homme Profil pro
    Développeur Java
    Inscrit en
    Mai 2014
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Mai 2014
    Messages : 1
    Par défaut JPA J2SE Persistence.xml
    Bonjour,

    Je fais du j2SE.

    En fait je veux juste me connecter à la bdd mysql.

    J'ai un serveur Glassfish 3 (jai suivi le tuto), mysql installé et bonecp déposé dans le bon dossier.

    J'ai crée une DATABASE toto avec une table client :

    CREATE TABLE CLIENT(
    IDCLIENT INTEGER NOT NULL PRIMARY KEY,
    NAME VARCHAR(32) NOT NULL,
    ) ENGINE = InnoDB;

    Apres j ai pris glassfish pour ceci:

    "Comme je vous l’ai annoncé un peu plus tôt, Tomcat ne gère pas les EJB de manière native. Et comme vous le savez maintenant, sans EJB pas de JPA. Nous pourrions certes ajouter les jar des différentes solutions dont nous allons avoir besoin pour continuer à travailler sous Tomcat, mais ce n’est pas ce que nous allons faire. Je souhaite en effet profiter de cette occasion pour vous faire travailler sur un autre serveur, un vrai serveur d’applications Java EE cette fois : GlassFish. Pas n’importe quel serveur d’ailleurs : il s’agit du serveur de référence, celui qui implémente à la lettre les spécifications Java EE 6. Rien d'étonnant me direz-vous, puisque c'est Oracle - la maison mère de tout l'écosystème Java - qui édite ce serveur !"

    Je ne me suis pas embeté, je me connecte via jdbc en tant que root.

    Voici mon fichier Client : (pour JPA)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    import javax.persistence.Entity;
    import javax.persistence.GeneratedValue;
    import javax.persistence.GenerationType;
    import javax.persistence.Id;
     
     
    @Entity
    public class Client {
     
        @Id
        @GeneratedValue( strategy = GenerationType.IDENTITY )
        private Long idclient;
     
        private String name;
     
        public String getName() {
            return name;
        }
     
        public void setName(String name) {
            this.name = name;
        }
    }
    Mon main:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    import javax.persistence.EntityManager;
    import javax.persistence.EntityManagerFactory;
    import javax.persistence.NoResultException;
    import javax.persistence.Persistence;
    import javax.persistence.PersistenceContext;
    import javax.persistence.Query;
     
    public class ClientDao {
        private static final String JPQL_SELECT_PAR_EMAIL = "SELECT u FROM Utilisateur u WHERE u.email=:email";
     
        public static void main(String[] argv) {
            EntityManagerFactory emf = Persistence.createEntityManagerFactory("Toto");
            EntityManager em = emf.createEntityManager();
            Client client = em.find(Client.class, 1);
            if (client != null) {
            System.out.println("Personne.nom=" + client.getName());
            }
            em.close();
            emf.close();
        }
    }
    Voila mon fichier de persistence :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    <?xml version="1.0" encoding="UTF-8"?>
    <persistence version="2.1" xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-
     
    instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence
     
    http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">
        <persistence-unit name="Toto">
        <provider>oracle.toplink.essentials.PersistenceProvider</provider>
        <class>Client</class>
        <properties>
            <property name="hibernate.connection.provider_class"
     
    value="com.jolbox.bonecp.provider.BoneCPConnectionProvider" />
            <property name="poolName" value="BoneCPPool"/>
            <property name="driverClass" value="com.mysql.jdbc.Driver"/>
            <property name="minConnectionsPerPartition" value="1"/>
            <property name="maxConnectionsPerPartition" value="20"/>
            <property name="acquireIncrement" value="2"/>
            <property name="partitionCount" value="1"/>
            <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/Toto"/>
            <property name="user" value="root"/>
            <property name="password" value="root"/>
            <property name="idleConnectionTestPeriodInMinutes" value="240"/>
            <property name="idleConnectionTestPeriodInSeconds" value="14400"/>
            <property name="idleMaxAgeInMinutes" value="60"/>
            <property name="idleMaxAgeInSeconds" value="3600"/>
            <property name="connectionTestStatement" value="/* ping *\/ SELECT 1"/>
            <property name="statementsCacheSize" value="0"/>
            <property name="releaseHelperThreads" value="3"/>
            <property name="closeConnectionWatch" value="false"/>
            <property name="logStatementsEnabled" value="false"/>
            <property name="acquireRetryDelayInMs" value="7000"/>
            <property name="lazyInit" value="false"/>
            <property name="transactionRecoveryEnabled" value="false"/>
            <property name="acquireRetryAttempts" value="5"/>
            <property name="disableJMX" value="false"/>
            <property name="queryExecuteTimeLimitInMs" value="0"/>
            <property name="poolAvailabilityThreshold" value="20"/>
            <property name="disableConnectionTracking" value="false"/>
            <property name="connectionTimeoutInMs" value="0"/>
            <property name="closeConnectionWatchTimeoutInMs" value="0"/>
            <property name="statementReleaseHelperThreads" value="0"/>
            <property name="maxConnectionAgeInSeconds" value="0"/>
            <property name="statisticsEnabled" value="false"/>
            <property name="externalAuth" value="false"/>
            <property name="deregisterDriverOnClose" value="false"/>
        </properties>
        </persistence-unit>
    </persistence>
    Le probleme c'est que ça me retourne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Exception in thread "main" javax.persistence.PersistenceException: No Persistence provider for EntityManager named Toto
        at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:85)
        at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:54)
        at ClientDao.main(ClientDao.java:12)


    Ah ! J allais oublier, j'ai aussi le bon bonecp (la version 0.8)

    J'aimerais garder une interaction avec bonecp pour gerer le pool

    Quelqu'un pourrait m'aider ?

    Cordialement.

  2. #2
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Par défaut
    bonjour,
    Citation Envoyé par Haziel Elijah Voir le message
    Et comme vous le savez maintenant, sans EJB pas de JPA.
    Celui qui a écrit ça, a dit une grosse ânerie !
    Il est tout a fait possible de faire du JPA en Java SE !
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre confirmé
    Homme Profil pro
    Développeur Java
    Inscrit en
    Mars 2014
    Messages
    67
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

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

    Informations forums :
    Inscription : Mars 2014
    Messages : 67
    Par défaut
    [/CODE]
    tu devrai plutot utiliser une classe ClientDAO

    et n oublie pas d'utilise l'annotation @PersistenceUnit
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    public class ClientDAO{
     @PersistenceContext(unitName = "toto")
     
    private entityManager  entity;
     
    public void addClient(Client client){
    entity.persist(client);
    }
     
    }

Discussions similaires

  1. Questions sur persistence.xml -> intéropérabilité JPA
    Par Gugelhupf dans le forum Hibernate
    Réponses: 2
    Dernier message: 19/08/2014, 16h27
  2. Réponses: 6
    Dernier message: 13/07/2012, 22h02
  3. Réponses: 5
    Dernier message: 26/06/2012, 12h37
  4. Réponses: 7
    Dernier message: 07/01/2008, 15h56
  5. Persistance xml
    Par safazz dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 07/12/2005, 16h30

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