ошибка настройки списка гибернации java EE «многие ко многим»

#mysql #hibernate #jsp #jakarta-ee

#mysql #переход в режим гибернации #jsp #джакарта-ee

Вопрос:

Я создаю веб-приложение java ee. У меня есть классы User и Permission, а в классе User есть список типов разрешений. Когда hibernate получает базу данных формы пользовательского объекта, я также хочу получить разрешения пользователя из таблицы user_permission. Пользователь и разрешение имеют отношение «многие ко многим». Я использую Hibernate 5.4.1. При настройке SessionFactory я получаю эту ошибку:

 java.lang.NullPointerException
    org.hibernate.boot.model.source.internal.hbm.ModelBinder$AbstractPluralAttributeSecondPass.bindCollectionElement(ModelBinder.java:3557)
    org.hibernate.boot.model.source.internal.hbm.ModelBinder$AbstractPluralAttributeSecondPass.doSecondPass(ModelBinder.java:3136)
    org.hibernate.boot.internal.InFlightMetadataCollectorImpl.processSecondPasses(InFlightMetadataCollectorImpl.java:1684)
    org.hibernate.boot.internal.InFlightMetadataCollectorImpl.processSecondPasses(InFlightMetadataCollectorImpl.java:1652)
    org.hibernate.boot.model.process.spi.MetadataBuildingProcess.complete(MetadataBuildingProcess.java:286)
    org.hibernate.boot.model.process.spi.MetadataBuildingProcess.build(MetadataBuildingProcess.java:83)
    org.hibernate.boot.internal.MetadataBuilderImpl.build(MetadataBuilderImpl.java:473)
    org.hibernate.boot.internal.MetadataBuilderImpl.build(MetadataBuilderImpl.java:84)
    org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:689)
    org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:724)
  

мой пользовательский класс:

 public class User
{
    private int id;
    private String name;
    private String password;
    private List<Permission> permissions;
    public User(){}
    public User(String name,String password)
    {
        this.name=name;
        this.password=password;
    }
    public String getName()
    {
        return name;
    }
    public void setName(String name)
    {
        this.name=name;
    }
    public String getPassword()
    {
        return password;
    }
    public void setPassword(String password)
    {
        this.password=password;
    }
    public int getId()
    {
        return id;
    }
    public void setId(int id)
    {
        this.id=id;
    }
    public void clearPermissions()
    {
        permissions.clear();
    }
    public boolean hasPermission(Permission permission)
    {
        return permissions.contains(permission);
    }
    public void addPermission(Permission permission)
    {
        permissions.add(permission);
    }
    public void deletePermission(Permission permission)
    {
        permissions.remove(permission);
    }
    public List<Permission> getPermissions()
    {
        return permissions;
    }
    public void setPermissions(List<Permission> permissions)
    {
        this.permissions = permissions;
    }
}
  

сопоставление пользовательских классов :

 <?xml version="1.0" encoding="UTF-8"?>
<hibernate-mapping>
    <class name="model.User" table="user">
        <id name="id" type="int" column="id">
            <generator class="identity"/>
        </id>
        <property name="name" column="name" type="string"/>
        <property name="password" column="password" type="string"/>
        <list name="permissions" table="user_permission" lazy="false">
            <key column="user_id"/>
            <index column="id"/>
            <many-to-many class="Permission" column="permission_id"/>
        </list>
    </class>
</hibernate-mapping>
  

мой класс разрешений:

 public class Permission
{
    private int id;
    private String name;
    public Permission() {}
    public Permission(int id, String name)
    {
        this.id=id;
        this.name=name;
    }
    public String getName()
    {
        return name;
    }
    public void setName(String name)
    {
        this.name=name;
    }
    public int getId()
    {
        return id;
    }
    public void setId(int id)
    {
        this.id=id;
    }
    public boolean equals(Object obj)
    {
        return ((Permission)obj).id==id;
    }
}
  

Сопоставление классов разрешений :

 <?xml version="1.0" encoding="UTF-8"?>
<hibernate-mapping>
    <class name="model.Permission" table="permission">
        <id name="id" type="int" column="id">
            <generator class="identity"/>
        </id>
        <property name="name" column="name" type="string"/>
    </class>
</hibernate-mapping>
  

Комментарии:

1. это должно быть «один ко многим», а не «многие ко многим»

2. Но в базе данных таблицы пользователей и разрешений «многие ко многим». Потому что разрешение может быть предоставлено многим пользователям, и у пользователя может быть много разрешений.

3. в отношениях «многие ко многим» мы получаем третью таблицу, где она определена?

4. Имя третьей таблицы — «user_permission» . В этой таблице 3 столбца: id, user_id,permission_id

5. О, спасибо, это решило мою проблему

Ответ №1:

В сопоставлении «многие ко многим» отсутствует packageName. Измените его с разрешения на модель.Разрешение. Это должно решить проблему. Ниже приведен sippet

 <class name="model.User" table="user">
    <id name="id" type="int" column="id">
        <generator class="identity"/>
    </id>
    <property name="name" column="name" type="string"/>
    <property name="password" column="password" type="string"/>
    <list name="permissions" table="user_permission" lazy="false">
        <key column="user_id"/>
        <index column="id"/>
        <many-to-many class="model.Permission" column="permission_id"/>
    </list>
</class> </hibernate-mapping>