Hibernate的核心对象关系映射

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+~)反引号,不然就要改列名;

 1 <?xml version="1.0"?>
 2 <!DOCTYPE hibernate-mapping PUBLIC 
 3     "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
 4     "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
 5     
 6 <!-- 
 7     第一部分:映射文件:映射一个实体类对象,用来描述一个对象最终实现可以直接保存对象数据到数据库中
 8     package(可选):要映射的对象即实体类所在的包,如果不指定package,那么下面所有的类都要指定全路径        
 9  -->    
10 <hibernate-mapping package="com.bie.po"> 
11     <!-- 操作条件:(1):对象与表/(2):属性与字段的对应/(3):类型的对应,类型默认采用属性的类型,type不写的话
12      -->
13      
14     <!-- 第二部分:
15         (1):class:映射某一个对象的(一般情况下,一个对象写一个映射文件,即一个class节点); 
16               name:指定要映射的对象的类型,实体类名称;
17               table:指定要映射的表,表名称;
18         (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方式;             -->
19         (3):普通字段映射:property
20             name:指定对象的属性名称;
21             column:指定对象属性对应的表的字段名称,如果不写默认与对象属性一致 ;    
22             length:用于指定字符类型长度,比如字符串类型varchar(20),默认长度255;
23             type:用于指定表的字段的类型,如果不指定,会匹配属性的类型,包含两种类型;
24                 java类型:必须写全名,比如java.lang.String,java.util.Date
25                 hibernate类型:比如string,date,都是小写,不能写String(不能首字母大写)
26                 注意:desc关键字,可以使用``(不是shift+~是直接~键)反引号或者改列名
27     -->
28     <class name="User" table="user">
29         <!-- 主键,映射 -->
30         <id name="id" column="id">
31             <generator class="native"></generator>
32         </id>
33         
34         <!-- 非主键,映射 -->       <!--             非主键映射,普通字段的映射            name:字段的属性名称,其他字段可以不写;            column:对应的数据表的字段名称;            length:自定字符类型的长度,只能指定字符类型的,如果不指定,默认为255;            type:指定数据表的字段的类型,如果不指定会匹配属性的类型:                java类型:必须写全名,如java.lang.String;                hibernate类型:string类型;直接写类型,都是小写          -->
35         <property name="name" column="name"></property>
36         <property name="password" column="password"></property>
37         <property name="email" column="email"></property>
38         <property name="phone" column="phone"></property>
39         
40         
41     </class>
42 
43 </hibernate-mapping>

格力,掌握核心科技,让消费者爱上中国造!!!

Hibernate,掌握映射核心知识,让老板给你升职加薪!!!~..~

最后讲解一下如何查看Hibernate的api哦,很实用的哦~..~

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏chenssy

【死磕Sharding-jdbc】---结果合并

接下来以执行 SELECT o.*FROM t_order o whereo.user_id=10order byo.order_id desc limit 2...

1033
来自专栏程序员宝库

一些我认为有用有趣的 JDK 方法

在学习JDK的源码过程中我遇到了一些有趣有用的方法,在此之前如果要使用这些工具方法,我首先会想到的是 commons-lang和 guava这样的语言扩展包,但...

2667
来自专栏JadePeng的技术博客

使用Mongodb 做对象缓存

mongodb高效的访问速度,用来快速存取数据再合适不过了,缓存神马的,可以用这个的 另外,有的时候,如果仅仅存储几条数据,单独去建立一张表代价太大,这个时候,...

3315
来自专栏JMCui

HQL查询

       HQL(Hibernate QueryLanguage) 是面向对象的查询语言,它和SQL查询语言有些相似。 1、Select/update/de...

2213
来自专栏图形学与OpenGL

《鲜活的数据-第2章 处理数据》有关代码

802
来自专栏加米谷大数据

Hive内置运算符

Hive有四种类型的运算符: 关系运算符 算术运算符 逻辑运算符 复杂运算符 关系运算符 这些操作符被用来比较两个操作数。下表描述了在Hive中可用的关系运...

3206
来自专栏前端儿

在JS中统计函数执行次数与执行时间

不过在Chrome中内置了一个 console.count 方法,可以统计一个字符串输出的次数。我们可以利用这个来间接地统计函数的执行次数

1073
来自专栏向治洪

迭代子模式

概述 概念:在阎宏博士的《JAVA与模式》中关于迭代子模式的定义是这样的:迭代子模式又叫游标(Cursor)模式,是对象的行为模式。迭代子模式可以顺序地访问一个...

1777
来自专栏我和PYTHON有个约会

09.程序编程基础3~组合数据类型

python中为了方便一部分相似数据的处理,提供了各种组合类型,常见的如列表、元组 python中的列表是可变序列,元组是不可变序列

501
来自专栏JMCui

Hybris IMPEX

1、Impex是基于java Model的一种面向对象的数据操作手段,因此写impex代码前需要理清java Model之间的依赖关系。 2、基本语法:mode...

3396

扫码关注云+社区