当前位置: 首页 > 面试题库 >

无法删除或更新父行:外键约束失败(休眠xml映射)

尹晟
2023-03-14
问题内容

我想删除其中用户为所有者的所有组,但目前无法使用。我认为在映射User.hbm.xml或Group.hbm.xml的级别上缺少某些东西,但我不知道。错误为
“无法删除或更新父行:外键约束失败(sharedmapgroupe,CONSTRAINT
FK_gq7win10rtxufsxu1n5istm2pFOREIGN KEY(user_id)参考userid))”

以下是相关的类和文件xml:

User.java

public class User {

    /** Attributs */


    @XmlTransient
    private Set<Group> proprietaire;

    /** Constructeur */ 
    public User() {
    }

    public User(String telephone, String pseudo, String email) {
        super();
        this.pseudo = pseudo;
        this.telephone = telephone;
        this.email = email;
    }


    public Set<Group> getProprietaire() {
        return proprietaire;
    }

    public void setProprietaire(Set<Group> proprietaire) {
        this.proprietaire = proprietaire;
    }

    ...

}

UserDao

public class UserDao {

    private static SessionFactory sessionFactory = SessionConfiguration.getFactory();

    /**
     * Method to ADD a user in the database
     * 
     * @param user
     * @return user_id
     */
    public static Integer addUser(User user) {
        Integer userID = null;
        Session session = sessionFactory.openSession();
        Transaction tx = null;

        try {
            tx = session.beginTransaction();
            userID = (Integer) session.save(user);          
            tx.commit();
        } catch (HibernateException e) {
            if (tx != null)
                tx.rollback();
            e.printStackTrace();
        } finally {
            session.close();
        }
        return userID;
    }

    /**
     * 
     * Method to DELETE a user from the records
     * 
     * @param telephone
     */
    public static void deleteUser(String telephone) {
        Session session = sessionFactory.openSession();
        Transaction tx = null;
        String query = "select u from User u where u.telephone = :telephone";
        User user = (User) session.createQuery(query)
                .setString("telephone", telephone).uniqueResult();
        try {
            tx = session.beginTransaction();
            session.delete(user);
            tx.commit();
        } catch (HibernateException e) {
            if (tx != null)
                tx.rollback();
            e.printStackTrace();
        } finally {
            session.close();
        }
    }
}

User.hbm.xml

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
 "-//Hibernate/Hibernate Mapping DTD//EN"
 "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
   <class name="modele.User" table="user">
      <meta attribute="class-description">
         This class contains the user detail. 
      </meta>
      <id name="id" type="int" column="id">
         <generator class="native"/>
      </id>
      <property name="pseudo" column="pseudo" type="string"/>
      <property name="telephone" column="telephone" type="string" not-null="true" unique="true"/>
      <property name="email" column="email" type="string"/>

      <!--  Mapping Set<Demande> demandes -->
      <set name="demandes" cascade="save-update,delete" lazy="false">
         <key column="demandeur_id"/>        
         <one-to-many class="modele.Demande"/>
      </set>

      <!--  Mapping Set<Invitation> aInvite -->
      <set name="aInvite" cascade="save-update,delete" lazy="false">
         <key column="inviteur_id"/>
         <one-to-many class="modele.Invitation"/>
      </set>

      <set name="notifications" cascade="save-update,delete" lazy="false">
         <key column="user_id"/>
         <one-to-many class="modele.Notification"/>
      </set>


      <set name="groups"  table="participation" lazy="false" inverse="true">
         <key column="user_id"/>
         <many-to-many column="group_id" class="modele.Group"/>
      </set>

     <!--  Mapping Set<Group> proprietaire -->
      <set name="proprietaire" cascade="save-update,delete" lazy="false">
         <key column="user_id"/>
         <one-to-many class="modele.Group"/>
      </set>

   </class>
</hibernate-mapping>

Group.hbm.xml

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
 "-//Hibernate/Hibernate Mapping DTD//EN"
 "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
   <class name="modele.Group" table="groupe">
      <meta attribute="class-description">
         This class contains the publicEvent detail. 
      </meta>
      <id name="id" type="int" column="id">
         <generator class="native"/>
      </id>
      <property name="description" column="description" type="string"/>
      <property name="hashtag" column="hashtag" type="string"/>
      <property name="password" column="password" type="string"/>
      <!--  Mapping ArrayList<Marqueur> marqueurs -->

      <set name="marqueurs" cascade="save-update,delete" lazy="false">
         <key column="group_id"/>
         <one-to-many class="modele.Marqueur"/>
      </set>
      <!--  Mapping Set<Invitation> invitations -->
      <set name="invitations" cascade="save-update,delete" lazy="false">
         <key column="group_id"/>
         <one-to-many class="modele.Invitation"/>
      </set>

      <!--  Mapping Set<Demande> demandes -->
      <set name="demandes" cascade="save-update,delete" lazy="false">
         <key column="group_id"/>
         <one-to-many class="modele.Demande"/>
      </set>

      <!--  Mapping User proprietaire -->
      <many-to-one name="proprietaire" class="modele.User" column="user_id" not-null="true"/>

      <!--  Mapping ArrayList<User> invites -->
      <set name="invites" table="participation" lazy="false">
         <key column="group_id"/>
         <many-to-many column="user_id" class="modele.User"/>
      </set>

   </class>
</hibernate-mapping>

UserDaoTest.java

public class UserDaoTest {

    private final String tel = "0601020304";
    private final String pseudo = "pseudo";
    private final String pseudoModified = "pseudo2";
    private final String email = "email@email.com";

    @Test
    public void addUserTest(){

        User initialUser = new User(tel, pseudo, email);

        // Add user in database
        UserDao.addUser(initialUser);

        User addedUser = UserDao.getUser(tel);

        // Add Group in User
        Group group = new Group();
        group.setDescription("description");
        group.setHashtag("hashtag");
        group.setPassword("password");
        //Set group proprietaire
        group.setProprietaire(addedUser);

        //Add group in database
        GroupDao.addGroup(group);

        // Add Group in User
        Set<Group> groups = new HashSet<Group>();
        groups.add(group);
        addedUser.setGroups(groups);

        Assert.assertEquals(addedUser.getTelephone(), initialUser.getTelephone());
        Assert.assertEquals(addedUser.getPseudo(), initialUser.getPseudo());
        Assert.assertEquals(addedUser.getEmail(), initialUser.getEmail());
    }


    @Test
    public void deleteUserTest(){
        User user = UserDao.getUser(tel);

        UserDao.deleteUser(user.getTelephone());

        List<User> listUsers = UserDao.listUser();

        Assert.assertFalse(listUsers.contains(user));
    }
}

问题答案:

请尝试将inverse = true添加到专有的用户文件集名称中,也请使用cascade = all“,delete-orphan

当删除用户时,这将删除组。另外,请特别注意如何在Hibernate中删除用户:

必须先刷新会话,然后才能删除用户。
必须从所有活动会话和2级缓存中逐出与您的用户链接的所有组。



 类似资料:
  • 我想删除所有的组,其中一个用户是所有者,但它目前不起作用。我认为在映射用户的级别上存在一些不足之处。哈佛商学院。xml或组。哈佛商学院。但是我不知道。错误是“无法删除或更新父行:外键约束失败(,约束外键()引用()” 以下是与xml相关的类和文件: 使用者JAVA 用户道 使用者哈佛商学院。xml 组哈佛商学院。xml UserDaoTest。JAVA

  • 问题内容: 进行时: 错误: 这是我的桌子: 问题答案: 照原样,必须先删除Advertisers表中的行,然后才能删除它引用的Jobs表中的行。这个: …实际上与应有的相反。实际上,这意味着您必须在作业表中有一条记录,然后才是广告商。因此,您需要使用: 纠正外键关系后,您的delete语句将起作用。

  • 我还在学习hibernate中的很多东西,以及如何处理hibernate中表与表之间的关系,所以在我的一个项目中,我面临着以下问题: 问题出在哪里? 我想做什么? 我正在尝试删除package实体,但不删除package表中引用的用户 我正在通过packageDAO对package实体调用delete

  • 我将按id删除对象,但出现如下错误: com。mysql。jdbc。例外情况。jdbc4。MySQLIntegrityConstraintViolationException:无法删除或更新父行:外键约束失败(,constraint外键()引用) 我按id删除的方法是: 我的表的映射看起来像: Selection.java 作业Audit.java 审核组。JAVA AssignmentAudit

  • 我在这里使用了多对一双向关系,一旦我被放入数据库,我就不能删除文件,如果我试图删除,我会遇到异常,无法删除或更新父行:外键约束失败。 这是我的另一个实体类... 嗨这是我的完整栈迹

  • 问题内容: 我正在研究一个基本示例来测试操作,但出现异常。 我有以下实体: Employee.java EmpDetails.java 现在我在数据库中有员工ID为10的记录,在员工详细信息表中有相应的记录。 现在,当我在查询下面运行时: 我在想hibernate将删除员工记录和相应的员工详细信息记录,因为我已设置要删除的层叠类型。但我得到异常为: 引起原因:com.mysql.jdbc.exce