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 等,这些属性到后面再做介绍。

相关文章
|
24天前
|
XML 前端开发 Java
讲解SSM的xml文件
本文详细介绍了SSM框架中的xml配置文件,包括springMVC.xml和applicationContext.xml,涉及组件扫描、数据源配置、事务管理、MyBatis集成以及Spring MVC的视图解析器配置。
47 1
|
25天前
|
XML JavaScript Java
java与XML文件的读写
java与XML文件的读写
17 3
|
26天前
|
XML 存储 缓存
C#使用XML文件的详解及示例
C#使用XML文件的详解及示例
54 0
|
27天前
|
XML 存储 Web App开发
查看 XML 文件
查看 XML 文件
|
2月前
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
43 1
|
6月前
|
SQL 缓存 Java
框架分析(9)-Hibernate
框架分析(9)-Hibernate
|
1天前
|
缓存 Java 数据库连接
Hibernate:Java持久层框架的高效应用
通过上述步骤,可以在Java项目中高效应用Hibernate框架,实现对关系数据库的透明持久化管理。Hibernate提供的强大功能和灵活配置,使得开发者能够专注于业务逻辑的实现,而不必过多关注底层数据库操作。
5 1
|
3月前
|
SQL Java 数据库连接
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。通过映射机制,它可以自动处理对象与数据库表之间的转换,支持主流数据库,提高了代码的可移植性和可维护性。其核心接口包括 SessionFactory、Session 和 Transaction 等,通过它们可以执行数据库的 CRUD 操作。配置方面,需在项目中引入 Hibernate 及数据库驱动依赖,并创建 `hibernate.cfg.xml` 配置文件来设置数据库连接和 Hibernate 行为参数。
43 1
|
3月前
|
数据库 Java 数据库连接
Struts 2 与 Hibernate 的完美邂逅:如何无缝集成两大框架,轻松玩转高效 CRUD 操作?
【8月更文挑战第31天】本文通过具体示例介绍了如何在 Struts 2 中整合 Hibernate,实现基本的 CRUD 操作。首先创建 Maven 项目并添加相关依赖,接着配置 Hibernate 并定义实体类及其映射文件。然后创建 DAO 接口及实现类处理数据库操作,再通过 Struts 2 的 Action 类处理用户请求。最后配置 `struts.xml` 文件并创建 JSP 页面展示用户列表及编辑表单。此示例展示了如何配置和使用这两个框架,使代码更加模块化和可维护。
64 0
|
4月前
|
SQL Java 数据库连接
Java面试题:简述ORM框架(如Hibernate、MyBatis)的工作原理及其优缺点。
Java面试题:简述ORM框架(如Hibernate、MyBatis)的工作原理及其优缺点。
68 0