hibernate的原理
hibernate的update
hibernate的delete
hibernate的查询(id的查询)
hibernate的关系映射
Hibernate中一对一关系(从表中的主键既是主键也是外键)
让两个实体的主键一样这样就不用加入多余的字段
主表
<class name="com.bjpowernode.hibernate.IdCard" table="t_idCard">
<id name="id">
<generator class="sequence">
<param name="sequnece">carid</param>
</generator>
</id>
<property name="cardNo" ></property>
<!--维护的是可以在查询主表的时候可以查询到从表中的数据。get或load时候发的sql语句是连接查询语句(无论查询主表还是从表) -->
<one-to-one name="person"></one-to-one>
</class>
从表
<class name="com.bjpowernode.hibernate.Person" table="t_person">
<id name="id">
<generator class="foreign">
<!--通过idCard找到主表中id -->
<param name="property">idCard</param>
</generator>
</id>
<property name="name"></property>
<!--constrained是告诉从表中的主键既是主键也是外键-->
<!--发的sql语句是1.查询的是主表中的数据发的就是连接查询2.查询的是从表中的数据发的就是一条数据-->
<one-to-one name="idCard" constrained="true"></one-to-one>
</class>
one-to-one指示hibernate如何加载其关联对象,默认根据主键加载
也就是拿到关系字段值,根据对端的主键来加载关联对象
constrained="true表示,当前主键(person的主键)还是一个外键
参照了对端的主键(IdCard的主键),也就是会生成外键约束语句
Hibernate中一对一关系(从表中的外键唯一){多对一的一种表现}
从表
<class name="com.bjpowernode.hibernate.Person" table="t_person">
<id name="id">
<generator class="sequence">
<!--通过idCard找到id -->
<param name="sequence">usid</param>
</generator>
</id>
<property name="name"></property>
<many-to-one name="idCard" cascade="save-update" unique="true"></many-to-one>
</class>
主表
<class name="com.bjpowernode.hibernate.IdCard" table="t_idCard">
<id name="id">
<generator class="sequence">
<param name="sequnece">carid</param>
</generator>
</id>
<property name="cardNo" ></property>
<!--标签中的property-ref属性为关系字段的名称为了可以通过外键查到从表中的数据(维护这种关系的是idCarid)-->
<one-to-one name="person" property-ref="idCard"/>
</class>