#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>