web-dev-qa-db-fra.com

Impossible de définir le champ Java.lang.Integer sur Java.lang.Integer

Déclaration de l'utilisateur:

@Entity
public class User {
    @Id
    @GeneratedValue
    private Integer id;
    ....

Déclaration de modèle:

@Entity
public class Pattern {
    @Id
    @GeneratedValue
    Integer id;
    ...

UserPatternDeclaration:

public class UserPattern {
    @Id
    @GeneratedValue
    Integer id;

    @ManyToOne
    @JoinColumn(name = "user_id")
    User user;

    @ManyToOne
    @JoinColumn(name = "pattern_id")
    Pattern pattern;
    ...

demande à la base de données:

Session session = sessionFactory.getCurrentSession();
Query query = session.createQuery("from UserPattern where user = :user_id and pattern = :pattern_id ");
query.setParameter("user_id", userId);
query.setParameter("pattern_id", pattern_id);
List<UserPattern> list = query.list();//exception throws here

J'ai eu l'exception suivante:

 ...
    Java.lang.IllegalArgumentException: Can not set Java.lang.Integer field 
    com.....s.model.User.id to Java.lang.Integer
        at Sun.reflect.UnsafeFieldAccessorImpl.throwSetIllegalArgumentException(UnsafeFieldAccessorImpl.Java:164)
        at Sun.reflect.UnsafeFieldAccessorImpl.throwSetIllegalArgumentException(UnsafeFieldAccessorImpl.Java:168)
        at Sun.reflect.UnsafeFieldAccessorImpl.ensureObj(UnsafeFieldAccessorImpl.Java:55)
        at Sun.reflect.UnsafeObjectFieldAccessorImpl.get(UnsafeObjectFieldAccessorImpl.Java:36)
        at Java.lang.reflect.Field.get(Field.Java:379)
    ....

S'il vous plaît aider à résoudre ce problème.

message d'erreur semble très très étrange.

J'ai lu un sujet connexe cliquez mais je n'ai pas trouvé de réponse.

P.S.

journal d'hibernation (avant exception):

Hibernate: 
    select
        userpatter0_.id as id1_2_,
        userpatter0_.amountSearched as amountSe2_2_,
        userpatter0_.amountplayed as amountpl3_2_,
        userpatter0_.pattern_id as pattern_4_2_,
        userpatter0_.user_id as user_id5_2_ 
    from
        UserPattern userpatter0_ 
    where
        userpatter0_.user_id=? 
        and userpatter0_.pattern_id=?

Dans le navigateur, je vois le message suivant:

HTTP Status 500....could not get a field value by reflection getter of...model.User.id
14
gstackoverflow

Que se passe-t-il si vous modifiez votre requête HQL en from UserPattern where user.id = :user_id and pattern.id = :pattern_id?

Je pense que Hibernate confond les objets et les champs d'identification.

15
Pimgd

Vous devez modifier votre requête comme suit:

from UserPattern where user.id = :user_id and pattern.id = :pattern_id

Dans votre requête, vous essayez de faire correspondre un objet User avec un objet Integer.

4
Priyesh

Si votre nom de champ est "id", vos méthodes getter et setter doivent être nommées

public Integer getId(){return id;}
public void setId(Integer id){this.id = id};

Si vous utilisez Eclipse, générez le getter/setter en clic droit -> Source -> Générer des Getters and Setters ...

Assurez-vous que vos accesseurs et votre passeur sont publics. Aussi, vous devriez ajouter @Table - Annotation à toutes vos entités.

1
dit

je pense que peut-être votre annotation devrait être 

@ManyToOne (TargetEntity = .... class)

0
T4Technologic