Hibernate的核心就是对象关系映射:

加载映射文件的两种方式:
  第一种:<mapping resource="com/bie/lesson02/crud/po/employee.hbm.xml"/>   第二种://便于测试,会自动加载映射文件:employee.hbm.xml
      private static SessionFactory sf;
     static{
      //加载主配置文件,并且创建session工厂
      sf = new Configuration()
      .configure()
      .addClass(Employee.class)
      .buildSessionFactory();
     }
1:第一掌握映射文件的书写:
    <hibernate-mapping package="com.bie.po"> </hibernate-mapping>
  2:第二掌握如何映射某一个对象,以及class里面主键和普通字段的设置。
    <class name="User" table="user"></class>
    2.1:主键映射
2.1.1:单列主键映射
<generator class=""></generator>
  主键映射:id
主键生成策略:
 identity:自增长(mysql,db2)
 native:自增长[会根据底层数据库自增长的方式选择identity或者sequence]
  如果是mysql数据库,采用自增长的方式是identity
  如果是oracle数据库,使用sequence序列的方式是先自增长
 sequence:自增长(序列),oracle中自增长是以序列方法实现
 increment:自增长,一般不用(会有并发访问的问题,一般在服务器集群环境使用会存在问题)
 assigned:指定主键生成策略为手动指定主键的值
 uuid:指定uuid随机生成全球唯一的值
 foreign:(外键的使用,one-to-one的时候使用)  

2.1.2:多列作为主键映射

(1)如果找不到合适的列作为主键,除了用id列,我们一般使用联合主键,即多列的值作为一个主键,从而保证记录的唯一性。

(2)联合主键的创建:

 create table person2(
    name VARCHAR(20),
    age INT,
    sex VARCHAR(5),
    PRIMARY key(name,age)
   )   

(3)创建一个实体类存放两个主键作为属性,并且实现set和get,并且必须实现可序列化;
   之后这个实体类和数据表中非两个主键的字段构成一个新的实体类,并且实现set和get方法,
   <class name="非两个主键字段创建的实体类的类名"> 
     <!-- 复合主键映射 -->
   <composite-id name="两个主键创建的实体类new的对象名称">
     <key-property name="第一个主键的名称" type="主键字段的类型"></key-property>
     <key-property name="第二个主键的名称" type="主键字段的类型"></key-property>
   </composite-id>
    </class>
 2.2:普通字段映射:property
  name:指定对象的属性名称;
  column:指定对象属性对应的表的字段名称,如果不写默认与对象属性一致 ;
  length:用于指定字符类型长度,比如字符串类型varchar(20),默认长度255;
  type:用于指定表的字段的类型,如果不指定,会匹配属性的类型,包含两种类型;
   java类型:必须写全名,比如java.lang.String,java.util.Date
   hibernate类型:比如string,date,都是小写,不能写String(不能首字母大写)       注意:property的column属性的值不能是sql语句的关键字,比如desc关键字做描述的时候,如果非要使用,         可以使用``(shift+~)反引号,不然就要改列名;
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <!--
第一部分:映射文件:映射一个实体类对象,用来描述一个对象最终实现可以直接保存对象数据到数据库中
package(可选):要映射的对象即实体类所在的包,如果不指定package,那么下面所有的类都要指定全路径
-->
<hibernate-mapping package="com.bie.po">
<!-- 操作条件:(1):对象与表/(2):属性与字段的对应/(3):类型的对应,类型默认采用属性的类型,type不写的话
--> <!-- 第二部分:
(1):class:映射某一个对象的(一般情况下,一个对象写一个映射文件,即一个class节点);
name:指定要映射的对象的类型,实体类名称;
table:指定要映射的表,表名称;
(2):主键映射:id
        <!-- 主键自增的 -->
<!--
主键生成策略,查看5.1.2.2.1.apiVarious additional generators
*identify:自增长(mysql,db2)
*native:自增长,会根据底层数据库自增长的方式选择identify或者sequence;
如果是mysql数据库,采用的是自增长方式是identify;
如果是oracle数据库,使用sequence序列的方式实现自增长;
*sequence:自增长(序列),oracle中自增长是以序列方式实现的。
increment:了解,自增长,会有并发访问的问题,一般在服务器集群环境使用会存在问题;
assigned指定主键生成策略为手动指定主键的值
uuid:指定uuid随机生成的序列号,唯一的值,为主键,uuid为string类型的
foreign:外键的方式,one-to-one方式;
-->
(3):普通字段映射:property
name:指定对象的属性名称;
column:指定对象属性对应的表的字段名称,如果不写默认与对象属性一致 ;
length:用于指定字符类型长度,比如字符串类型varchar(20),默认长度255;
type:用于指定表的字段的类型,如果不指定,会匹配属性的类型,包含两种类型;
java类型:必须写全名,比如java.lang.String,java.util.Date
hibernate类型:比如string,date,都是小写,不能写String(不能首字母大写)
注意:desc关键字,可以使用``(不是shift+~是直接~键)反引号或者改列名
-->
<class name="User" table="user">
<!-- 主键,映射 -->
<id name="id" column="id">
<generator class="native"></generator>
</id> <!-- 非主键,映射 -->
       <!--
非主键映射,普通字段的映射
name:字段的属性名称,其他字段可以不写;
column:对应的数据表的字段名称;
length:自定字符类型的长度,只能指定字符类型的,如果不指定,默认为255;
type:指定数据表的字段的类型,如果不指定会匹配属性的类型:
java类型:必须写全名,如java.lang.String;
hibernate类型:string类型;直接写类型,都是小写
  -->
<property name="name" column="name"></property>
<property name="password" column="password"></property>
<property name="email" column="email"></property>
<property name="phone" column="phone"></property> </class> </hibernate-mapping>

3hibernate核心对象关系映射 xxx.hbm.xml的更多相关文章

  1. 1-3 hibernate核心对象关系映射 xxx.hbm.xml

    详见  http://www.cnblogs.com/biehongli/p/6532800.html 1 <?xml version="1.0" encoding='utf ...

  2. [原创]java WEB学习笔记81:Hibernate学习之路--- 对象关系映射文件(.hbm.xml):hibernate-mapping 节点,class节点,id节点(主键生成策略),property节点,在hibernate 中 java类型 与sql类型之间的对应关系,Java 时间和日期类型的映射,Java 大对象类型 的 映射 (了解),映射组成关系

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  3. [原创]java WEB学习笔记77:Hibernate学习之路---Hibernate 版本 helloword 与 解析,.环境搭建,hibernate.cfg.xml文件及参数说明,持久化类,对象-关系映射文件.hbm.xml,Hibernate API (Configuration 类,SessionFactory 接口,Session 接口,Transaction(事务))

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  4. Hibernate的核心对象关系映射

    Hibernate的核心就是对象关系映射: 加载映射文件的两种方式: 第一种:<mapping resource="com/bie/lesson02/crud/po/employee. ...

  5. 【转】关系映射文件***.hbm.xml详解

    http://blog.sina.com.cn/s/blog_7ffb8dd5010144yo.html 附.Oracle使用标准.可变长度的内部格式来存储数字.这个内部格式精度可以高达38位. NU ...

  6. hibernate在配置文件中配置对象关系映射文件即hbm文件路径的写法

    hbm文件如果在src下,则<mapping resource="*.hbm.xml"/> 如果在实体类包中,则<mapping resource="c ...

  7. Hibernate (开源对象关系映射框架)

    一.基本介绍1.它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm(对象关系映射)框架,hibernate可以自动生成SQL语句,自动执行: Hibern ...

  8. JavaEE之Hibernate(开放源代码的对象关系映射框架)

    Hibernate(开放源代码的对象关系映射框架) 1.简介 Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全 ...

  9. 死去活来,而不变质:Domain Model(领域模型) 和 EntityFramework 如何正确进行对象关系映射?

    写在前面 阅读目录: 设计误区 数据库已死 枚举映射 关联映射 后记 在上一篇<一缕阳光:DDD(领域驱动设计)应对具体业务场景,如何聚焦 Domain Model(领域模型)?>博文中, ...

随机推荐

  1. Sharding-jdbc(一)分库分表理解

    1.什么是分库分表 所谓的分库分表就是数据的分片(Sharding). 2.为什么需要分库分表 因为随着公司的业务越来越大,对于现成单机单个应用瓶颈问题,对数据持久化硬盘如何进行扩容. 可以从4个方面 ...

  2. 基于HA机制的MyCat架构——配置HAProxy

    HAProxy简介HAProxy提供高可用性.负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费.快速并且可靠的一种解决方案. HAProxy特别适用于那些负载特大的web站点,这些站 ...

  3. es-05-获取 resthighlevelclient及api

    在6.x以前, 使用最多的是transportclient, 但在7.x会被废弃, 先说以前的创建方式: 具体可见:https://www.cnblogs.com/wenbronk/p/6383194 ...

  4. php里use关键字与class_alias的作用域区别

    use可以用在命名空间下,也可以不用再命名空间下,他在两者中的作用是一致的,都是在编译的时候执行,不真正的加载类,因为是编译的时候执行,所以只能在全局环境使用,及不能使用在方法内部,条件判断内部. 引 ...

  5. 【详解】ThreadPoolExecutor源码阅读(三)

    系列目录 [详解]ThreadPoolExecutor源码阅读(一) [详解]ThreadPoolExecutor源码阅读(二) [详解]ThreadPoolExecutor源码阅读(三) 线程数量的 ...

  6. linux 初始化工作环境

    #!/bin/sh # # init workspace # /bin/svnserve -d -r /home/oracle/projects --listen-port= su - oracle ...

  7. JavaScript时间操作工具类

    /** * 时间操作工具类 * * @author zwq * */ var TimeFrameUtil = { /** * 格式化日期 * @param date {Date} 日期 * @para ...

  8. Linux下删除Tomcat缓存

    step1:进入Tomcat的bin目录,停止Tomcat服务 ./shutdown.sh step2:进入Tomcat的work目录,删除work目录里面的全部文件 step3.启动Tomcat服务 ...

  9. Docker配置阿里云加速地址

    首先需要注册一个阿里云账号,只要注册账号就可以,不用充钱购买任何阿里云服务! 打开阿里云网站https://cr.console.aliyun.com,登陆自己的阿里云账号. 然后只需要在服务器配置d ...

  10. jQuery获取动态产生的html内标签或元素

    下午分享<MVC编辑状态两个DropDownList联动>http://www.cnblogs.com/insus/p/3426563.html 不久,马上有网友问及三级联动的例子.Ins ...