Is it possible to have foreign key enforced without object-to-object mapping?

前端 未结 4 644
佛祖请我去吃肉
佛祖请我去吃肉 2021-01-18 07:15

Assuming the following mappings are provided:


  
  

        
相关标签:
4条回答
  • 2021-01-18 07:54

    As said

    I understand that if I convert <many-to-one... into a <property... this would work, but foreign key would not be enforced by the database.

    So my advice is: use both

    public class EntityA {
    
        private Integer idOfB;
    
        private EntityB entityB;
    
        // getter's and setter's
    
    }
    

    And

    <class name="A" table="a_table">
        <id name="id"/>
        <property name="idOfB" column="fk_B" not-null="false" unique="true"/>
        <many-to-one name="entityB" update="false" insert="false" column="fk_B"/>
    </class>
    

    Notice when two properties share the same column, you have to put settings about it in just one property. Otherwise, Hibernate will complain some errors. It explains why i define update="false" and insert="false" in entityB property.

    regards,

    0 讨论(0)
  • 2021-01-18 07:54

    I recommend you to associate objects to objects to get full advantages of Hibernate. I think the problem is the exception you get. This is because Hibernate session is already closed when you try to get the lazy object. There are several posts in this blog which show answers to this problem, for example this one:link text.

    In case you're using spring you can use OpenEntityManagerInViewFilter so the session will keep opened until the view is renderes.

    0 讨论(0)
  • 2021-01-18 07:56

    You could always create the Foreign Key DDL manually in your hibernate hbm.xml file:

    <hibernate-mapping>
        ...
        <database-object>
            <create>[CREATE FK]</create>
            <drop>[DROP FK]</drop>
        </database-object> 
    </hibernate-mapping>
    

    You can also scope this if different dialects need to be supported.

    Check out 5.7. Auxiliary database objects

    0 讨论(0)
  • 2021-01-18 07:57

    Another approach you could take is to define the FK with your B mapping rather than the A mapping. I've added the JPA code, you'd have to translate this to your hibernate mapping file if you're not using annotations.

    @Entity
    public class B
    {
        private long id;
        private List<A> aList;
    
        @Id
        @Column( name = "ID" )
        public long getId()
        {
            return id;
        }
    
        @OneToMany
        @JoinColumn( name = "B_ID" )
        public List<A> getAList()
        {
            return aList;
        }
        public void setId( long id )
        {
            this.id = id;
        }
        public void setAList( List<A> aList )
        {
            this.aList = aList;
        }        
    }
    

    A.java would not look like this:

    @Entity
    public class A
    {
        private long id;
        private long idOfB;
    
        @Id
        @Column( name = "ID" )
        public long getId()
        {
            return id;
        }
        @Column( name = "B_ID" )
        public long getIdOfB()
        {
            return idOfB;
        }
        public void setId( long id )
        {
            this.id = id;
        }
        public void setIdOfB( long idOfB )
        {
            this.idOfB = idOfB;
        }   
    }
    
    0 讨论(0)
提交回复
热议问题