Hibernate映射文件配置

Hibernate配置:
一:hibernate基本数据类型
映射类型 Java类型 数据库sql类型(oracle)
int Java.lang.Integer
long Java.lang.Long number
string Java.lang.String char
string Java.lang.String varchar(2)
timestamp Java.sql.Timestamp date

二:实体映射
1 <hibernate-mapping package=””>
主要属性:package----指定一个包前缀,对于映射文件中没有全限定的类名,则默认使用该包前缀。
1.1 <class name=”持久化类的名称” table=”数据库表名”>
1.2 <id name=“持久化类的属性名” column=”数据库表的字段名” type=”hibernate基本数据类型”>
例如:<id name=”id” column=”USER_ID” type=”string” />无主键生成器
一般都为表设计一个没有实际意义的逻辑主键,hibernate为这种逻辑主键提供了主键生成器,它负责为每个实例化对象生成唯一的逻辑主键。(我们也可以不使用如上例所示)
Oracle中的表的主键是序列(sequence)自动生成的配置方法:
<id name=”id” column=”USER_ID” type=”long”>
<generator class=”sequence”>//这里class定义的hibernate的主键生成器类型(11大类)
<param name=”sequence”>W_PROG_SN</param>
</generator>
</id>
联合主键的配置:




1.3 映射普通属性
<property name=”” column=”” type=”” />










有如下表结构:

配置文件:
一 系统程序档的配置文件(W_PROG):
public class Program extends BaseEntity<Long>{
private String progName;
private Mod progMod;
    private String useRmk;
    private String urlPath;
    private String keyName;
    private Long seq;
    private String memo;
    private Wuser modifyUser;
    private Timestamp modifyDate;
private List<ProgDataKind> dataKinds=new ArrayList<ProgDataKind>();
private List<ProgBtn> progBtns = new ArrayList<ProgBtn>();

<class name="Program" table="W_PROG">//
<id name="id" column="PROG_ID" type="long">
<generator class="sequence">
<param name="sequence">W_PROG_SN</param>
</generator>
</id>//主键的配置
<property name="progName" column="PROG_NAME" type="string"></property>
<!-- 配置与模块之间的many-to-one关系 -->
<many-to-one name="progMod" class="Mod" column="MOD_ID"/>
普通属性的配置
<property name="useRmk" column="USE_RMK" type="string"></property>
<property name="urlPath" column="URL_PATH" type="string"></property>
<property name="keyName" column="KEY_NAME" type="string"></property>
<property name="seq" column="SEQ" type="long"></property>
<property name="memo" column="MEMO" type="string"></property>
<many-to-one name="modifyUser" class="Wuser" column="MODIFY_USER" />此表自己的字段
<property name="modifyDate" column="MODIFY_DATE" type="timestamp" />
<!-- 配置与W_PROG_DATAKIND表之间的N-1关系 -->使用bag 性能较好
Cascade:级联操作配置 :当需要使用到级联删除字表的数据时,需配delete-orphan。
<bag name="dataKinds" table=”W_PROG_DATAKIND” inverse="true"cascade=all,save-update,delete-orphan” 可以设置排序>
Inverse:用来标示由谁控制关联关系,我们都设置为由n得一段控制即此属性一般放在用bag 配置的一段
<key column=PROG_ID” />此key中的column配置的字段是W_PROG_DATAKIND表中的,外键
<one-to-many class="ProgDataKind" />
</bag>
配置与表W_PROG_BIN之间的n-1关系
<bag name="progBtns" table=” W_PROG_BIN”  cascade="all,save-update,delete-orphan" inverse="true" >
<key column="PROG_ID" />
<one-to-many class="ProgBtn" />
</bag>
</class>

二 程序资料类别档(W_PROG_DATAKIND)
由于此表中使用了组合主键,所以我们一般给它定义一个主键类:
ProgDataKindPk类是ProgDataKind的主键类
public class ProgDataKindPk extends BasePk{
private Program program;
private String kindNo;
一些get和set方法


public class ProgDataKind extends BaseEntity<ProgDataKindPk>{
private String kindName;

ProgDataKind的配置文件:
<hibernate-mapping package="com.byd.erpit.base.model">
   <class name="ProgDataKind" table="W_PROG_DATAKIND">
配置组合主键:由于ProgDataKind与Program之间的关系是many-to-one。
在Program的配置文件中我们可以看到有配置Program与ProgDataKind之间的<one-to-many class="ProgDataKind" />
       <composite-id name="id" class="ProgDataKindPk">
       <key-many-to-one name="program" class="Program" >
     <column name="PROG_ID" />
   </key-many-to-one>
   <key-property name="kindNo"  column="KIND_NO" type="string"/>
       </composite-id>
       <property name="kindName" column="KIND_NAME" type="string"/>
  </class>
</hibernate-mapping>

三 程序操作键档W_PROG_BTN
此表属于W_PROG与W_BTN关联关系中的一个中间表,因此此表只有两个字段
组合主键:
public class ProgBtnPk extends BasePk{
private Program program;
private Btn programBtn;
}
public class ProgBtn extends BaseEntity<ProgBtnPk>{
此对象无任何自己的属性
}
配置文件:
<hibernate-mapping package="com.byd.erpit.base.model">
   <class name="ProgBtn" table="W_PROG_BTN">
       <composite-id name="id" class="ProgBtnPk">
配置与W_PROG之间的many-to-one关系
       <key-many-to-one name="program" class="Program" >
     <column name="PROG_ID" />
   </key-many-to-one>
配置与W_BTN表之间的关系,单向的
   <key-many-to-one name="programBtn" class="Btn">
   <column name="BTN_NO" />
   </key-many-to-one>
       </composite-id>
  </class>
</hibernate-mapping>
四:程序操作键W_BTN
配置文件:
<hibernate-mapping package="com.byd.erpit.base.model">
   <class name="Btn" table="W_BTN">
       <id name="id" column="BTN_NO" type="string" />无主键生成器
       <property name="btnName" column="BTN_NAME" type="string" ></property>
       <property name="keyName" column="KEY_NAME" type="string" ></property>
       <property name="modifyUser" column="MODIFY_USER" type="long" ></property>
       <property name="modifyDate" column="MODIFY_DATE" type="timestamp" ></property>
   </class>
</hibernate-mapping>

你可能感兴趣的:(数据结构,oracle,sql,Hibernate)