Hibernate中hibernate.cfg.xml文件和Xxx.hbm.xml文件的详细解释(二)上

简介: Hibernate中hibernate.cfg.xml文件和Xxx.hbm.xml文件的详细解释(二)

Hibernate项目中,有两个特别重要的约束文件,hibernate.cfg.xml和Xxx.hbm.xml文件( 如User.hbm.xml,Person.hbm.xml文件)。


其中hiberante.cfg.xml是Hiberante的配置文件,cfg为config的简写。这个文件必须要放在src目录下面。


名称必须是hibernate.cfg.xml, 注意区分大小写。


接下来,老蝴蝶以上一章节的 User.hbm.xml 和 hibernate.cfg.xml 进行分析。


一. User.hbm.xml 约束文件


User.hibernate.xml约束文件是实体约束,最好要与其相对应的Java实体类保持一致。


如实体类为User,在pojo包下。则xml约束文件也要在pojo包下。


实体类名称为User,则xml的名称为User.hbm.xml。 hibernate.xml是Hibernate本身自己定义标记的。


一.一 dtd约束


<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">


一.二 根节点


User.hibernate.xml约束的根节点为: hibernate-mapping。 其中有一个主要的节点, package。


package表示包,指出类所在的路径为 com.yjl.pojo。


如果不指定这一个,那么下面所有的类都要用全限定名称,即class=“com.yjl.pojo.User”, 而不能用class=“User” 即可。


<hibernate-mapping package="com.yjl.pojo" >
</hibernate-mapping>


一.三 类节点


类节点为class. 里面有三个主要的属性。 name, 表示的为哪个类,即要映射的是哪一个类,里面填写的是类名。


如果在hibernate-mapping节点中没有指定package,那么这个时候要写入全限定名称,即name=“com.yjl.pojo.User”,


如果指定了package,那么这里只需要写入name=“User” 即可。 package与name的值共同构成了全限定名称。


table,表示生成后的表名。Hiberante可以自动建表,table指定建立表时的名称。 lazy,表示懒加载。默认为true.


懒加载的具体使用,老蝴蝶后面会讲。


<class name="User" table="user" lazy="true">
</class>


一.四 id属性标签


在每一个POJO中,都要有一个具体的标识符,这个标识符可以唯一确定对象,也就是数据库中的主键。


这个主键通常使用的是虚拟主键,不是真实的主键。虚拟主键,通常没有什么意义,只是表示不重复。


如学生表中,学生的学号是不能重复的,但是却最好不要将其当成主键。(学号表示真实主键),而应该设置一个虚拟的主键,为id. 为自动增长的。 这个id就表示虚拟主键。


主键生成策略有: 适用于自增长的increment。 用于int,long,short三种类型。 适用于Oracle数据库的序列 sequence.


还有根据底层数据库选择的 native, 不可重复的uuid。


20200615095814825.png


常见使用的是, native和uuid。


虚拟主键,自增长的用native. 常用于数字,这个数字只是起一个不重复的作用。 uuid生成唯一标识的,这个标识通常是有用的,复杂的,如订单的编号等,商品的编号等。


主键生成策略为native。


节点为id, name表示的是,类中的属性值。 column表示的是数据表中的字段值。 column可以省略,如果省略的话,默认与name中的值相同。


length表示长度,指定table中字段的长度. type 表示类型,将Java中的类型与数据库中的类型进行一一对应起来。


可以写Java中的全类型,如type=“java.lang.Integer” ,type=“java.lang.String” 也可以写成简写形式,


type=“int” ,type=“string”。 generator 指定主键的生成策略, class指定名称,为"native"。


<id name="id" column="id" length="11" type="int">
  <generator class="native"></generator>
</id>


也可以为这个字段添加相应的注释,即在数据库中对每个字段添加相应的备注。 如果添加备注,则需要这样写,此时就不能将column直接跟在name后面了,此时column必须放在generator的前面。 column中的name表示的是数据库中的字段值。


                <id name="id" length="11" type="int">
      <column name="id">
        <comment>这是一个虚拟的主键</comment>
      </column>
      <generator class="native"></generator>  
    </id>


生成后的表为:


20200615095827173.png


主键生成策略为UUID


如果主键生成策略是UUID的话,那么id此时就不能是Integer或者int类型了,就必须是String类型了。


private String uid, 生成uid的setter和getter方法。 然后在generator中令class=“uuid” 即可。


                <id name="uid" length="100" type="string">
      <column name="uid">
        <comment>这是一个uuid形式的主键</comment>
      </column>
      <generator class="uuid"></generator>  
    </id>


在保存对象时,不需要设置user.setUid() 的值,仍然与以前一样,不用管uid的值,系统会自动生成一个UUID的值,然后将其放置到uid中。


一.五 普通属性 property


在一个类中只有一个唯一标识符id, 其余的均是普通属性,用property节点。


property中有常见的name, 表示类中的属性值。 column表示数据表中字段值,length表示长度,type表示类型。 其中还有表示约束的值, not-null=“true” ,表示不为空的约束。not-null=“false”,表示可以为空。 unique=“true” 表示唯一约束。 unique=“false”,表示不是唯一的,可以重复的。


<property name="password" column="password" length="20" not-null="true" 
    type="string" unique="false"></property>


如果为普通属性添加备注的话,与id相同:


 <property name="password" length="20" not-null="true" type="string" unique="false">
  <column name="password">
    <comment>密码</comment>
  </column>
</property>


一.六 其余属性


还有其他的属性,如array, set,one-to-one,catch 等,这些属性到后面再做介绍。

相关文章
|
19天前
|
XML 数据格式
小米备份descript.xml文件
小米备份descript.xml文件
21 0
|
1天前
|
Android开发
android string.xml文件中的整型和string型代替
android string.xml文件中的整型和string型代替
|
1天前
|
XML 前端开发 数据格式
BeautifulSoup 是一个 Python 库,用于从 HTML 和 XML 文件中提取数据
BeautifulSoup 是 Python 的一个库,用于解析 HTML 和 XML 文件,即使在格式不规范的情况下也能有效工作。通过创建 BeautifulSoup 对象并使用方法如 find_all 和 get,可以方便地提取和查找文档中的信息。以下是一段示例代码,展示如何安装库、解析 HTML 数据以及打印段落、链接和特定类名的元素。BeautifulSoup 还支持更复杂的查询和文档修改功能。
8 1
|
1天前
|
XML 安全 API
AndroidManifest.xml文件综合详解
AndroidManifest.xml文件综合详解
|
13天前
|
XML 存储 Java
【OpenCV】—输入输出XML和YAML文件
【OpenCV】—输入输出XML和YAML文件
|
1月前
|
XML Java 数据库连接
mybatis中在xml文件中通用查询结果列如何使用
mybatis中在xml文件中通用查询结果列如何使用
33 0
|
1月前
|
XML JavaScript 前端开发
xml文件使用及解析
xml文件使用及解析
|
2月前
|
SQL
Mybatis.xml文件中大于小于等于
Mybatis.xml文件中大于小于等于
9 0
|
2月前
|
XML 关系型数据库 MySQL
【Mysql】有关数据库中一对多/一对一,多对一xml中文件映射问题
【Mysql】有关数据库中一对多/一对一,多对一xml中文件映射问题
19 0