一、多表的一个关联关系

老师和学生是一对多的关系

student:tid属性 外键约束 对应teacher表中的id属性

teacher:id

在myeclipse的db窗口中选中两个表来生成类。

 

写一个CRUD

//老师和学生实体保存

    public void save(){

        Teacher t=new Teacher();

        t.setName("彭老师");

        

        Student s1=new Student();

        s1.setName("郭靖");

        

        Student s2=new Student();

        s2.setName("杨康");

        

        s1.setTeacher(t);

        s2.setTeacher(t);

        

        Set<Student> ss=new HashSet<Student>();

        ss.add(s1);

        ss.add(s2);

        t.setStudents(ss);

        

        Session session=HibernateSessionFactory.getSession();

        Transaction tx=session.beginTransaction();

        session.save(s1);

        session.save(s2);

        tx.commit();

        HibernateSessionFactory.closeSession();

    }

 

此时实体是保存不进去的,需要在学生实体的hbm.xml配置文件中的many-to-one 标签中添加cascade="all" 设置级联级别为all

 

<many-to-one
name="teacher" class="com.hibernate.entity.Teacher"
fetch="select"
cascade="all">

<column
name="tid"
/>

</many-to-one>

此时数据才可插入成功。老师和学生都可以保存。

 

①对象的三种状态

1临时状态:

使用new命令开辟内存空间的Java对象,在内存中孤立存在

2持久状态:

数据库中存在。

3游离状态

与Session关联的对象

 

由类和配置文件生成表的类

    Configuration cfg = new Configuration().configure("/hibernate.cfg.xml");

        SchemaExport export = new SchemaExport(cfg);

        export.create(true, true);

 

 

手写一个配置文件

Stu.hbm.xml

    <class
name="com.hibernate.model.Stu"
table="t_stu">

        <id
name="id">

            <column
name="id"></column>

            <generator
class="uuid"></generator>

        </id>

        

        <property
name="name"></property>

        <property
name="age"></property>

        <many-to-one
name="teacher"
class="com.hibernate.model.Teacher"
cascade="save-update">

            <column
name="tid"></column>

        </many-to-one>

    </class>

 

Theacher.hbm.xml

<?xml
version="1.0"
encoding="utf-8"?>

<!DOCTYPE hibernate-mapping
PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"

"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

 

<hibernate-mapping>

    <class
name="com.hibernate.model.Teacher"
table="t_table">

        <id
name="id">

            <column
name="id"/>

            <generator
class="uuid"></generator>

        </id>

        <property
name="name"></property>

        <set
name="stus"
cascade="delete">

            <key>

                <column
name="tid"></column>

            </key>

            <one-to-many
class="com.hibernate.model.Stu"/>

        </set>

    </class>

</hibernate-mapping>

 

还要在hibernate.cfg.xml

添加:

    <mapping
resource="com/hibernate/model/Teacher.hbm.xml"
/>

    <mapping
resource="com/hibernate/model/Stu.hbm.xml"
/>

 

 

三 id的生成策略

<id name="实体类属性名" type="java.lang.Integer">

<column name="对应表中主键字段名" />

<generator class="assiged|increment|identity|native|........" />

</id>

generator class的属性如下:

  1. identity 数据库自动增长的 Oracle数据库不支持

②increment 程序调用增长的 select max(id)from table

他们的共性是都是自增长,程序员无序指定属性值。

③uuid 通过Java.util.uuid类生成的唯一的标识符,

④native 将主键的生成交给数据库,hibernate不管。

⑤assigned 在插入主键的时候由程序处理。

⑥sequence 调用底层数据库序列生成主键,适用于Oracle

 

 

四cascade的属性

  1. save-update当保存或修改对象时,级联保存所有与之关联的临时对象,级联更新所有与之关联的托管对象。
  2. delete 如果老师删了的话 学生也就没了。级联删除所有与之关联的对象。
  3. all 包括save-update和delete 的所有属性

     

 

inverse 老师放弃维护关系,级联保存的时候

节省update的语句

指定谁来维护关联关系,不是必须的,在关联关系中,通常让多的那一方来维护关联关系。

 

 

 

五继承关系映射

鉴别器

 

product book ps

三种方式 类的结构相同 配置文件不同导致 映射出来的表结构不一样。

 

第一种方式 不同对象生成的一张表,表中的字段会因类型的不同留空

<hibernate-mapping>

    <class
name="com.hibernate.entity.Product"
table="t_product"
discriminator-value="A">

        <id
name="id"
>

            <column
name="id"
/>

            <generator
class="uuid"></generator>

        </id>

        <discriminator
column="type"
type="string"></discriminator>

        <property
name="name"></property>

        <property
name="price"></property>

        <subclass
name="com.hibernate.entity.Book"
discriminator-value="B">

            <property
name="author"></property>

        </subclass>

        <subclass
name="com.hibernate.entity.Ps"
discriminator-value="P">

            <property
name="handler"></property>

        </subclass>

        </class>

</hibernate-mapping>

 

第二种方式

每一个类建立自己的一张表 ,表间的一对一关系用外键关联描述

Jioned-subclass 来描述子表特有的属性

<hibernate-mapping>

    <class
name="com.hibernate.entity.Product"
table="t_product">

        <id
name="id"
type="java.lang.String">

            <generator
class="uuid"/>

        </id>

        <property
name="name"
type="java.lang.String">

            <column
name="name"
length="20"/>

        </property>

        <property
name="price"
type="java.lang.Double"></property>

        <joined-subclass
name="com.hibernate.entity.Book"
table="t_book">

            <key
column="bid"></key>

            <property
name="author"></property>

        </joined-subclass>

        

        <joined-subclass
name="com.hibernate.entity.Ps"
table="t_Ps">

            <key
column="pid"></key>

            <property
name="handler"></property>

        </joined-subclass>

    </class>

</hibernate-mapping>

 

第三种方式 将每个类的所有属性都建立一个表,(包含着父类的所有属性)

Unioned-subclass

<hibernate-mapping>

<class
name="com.hibernate.entity.Product"
table="t_product">

<id
name="id"
type="java.lang.String">

<generator
class="uuid"
/>

</id>

 

<property
name="name"
type="java.lang.String">

<column
name="NAME"
length="20"
/>

</property>

 

<property
name="price" type="java.lang.Double">

</property>

 

<union-subclass
name="com.hibernate.entity.Book"
table="t_book">

    <property
name="author"></property>

</union-subclass>

<union-subclass
name="com.hibernate.entity.Ps"
table="t_ps">

    <property
name="handler"></property>

</union-subclass>

</class>

</hibernate-mapping>

 

使用crud进行测试

package com.hibernate.dao;

 

import java.util.HashSet;

import java.util.Set;

 

import org.hibernate.Hibernate;

import org.hibernate.Session;

import org.hibernate.Transaction;

 

import com.hibernate.entity.Book;

import com.hibernate.entity.Product;

import com.hibernate.entity.Ps;

import com.hibernate.model.Teacher;

import com.hibernate.model.Stu;

import com.hibernate.util.HibernateSessionFactory;

 

public class CRUD {

    //老师和学生实体保存

    public void save(){

        Teacher t=new Teacher();

        t.setName("彭老师");

        

        Stu s1=new Stu();

        s1.setName("郭靖");

        

        Stu s2=new Stu();

        s2.setName("杨康");

        

        s1.setTeacher(t);

        s2.setTeacher(t);

        

        Set<Stu> ss=new HashSet<Stu>();

        ss.add(s1);

        ss.add(s2);

        t.setStus(ss);

        

        Session session=HibernateSessionFactory.getSession();

        Transaction tx=session.beginTransaction();

        session.save(s1);

        session.save(s2);

        tx.commit();

        HibernateSessionFactory.closeSession();

    }

    //保存 product对象

    public void save2(){

        Product p=new Product();

        p.setName("产品");

        p.setPrice(100.00);

        Book b=new Book();

        b.setName("钢铁是怎样练成的");

        b.setPrice(99.9);

        b.setAuthor("奥斯特洛夫斯基");

        

        Ps p1=new Ps();

        p1.setName("play station");

        p1.setPrice(230);

        p1.setHandler("尼古拉");

        

        Session session=HibernateSessionFactory.getSession();

        Transaction tx=session.beginTransaction();

        session.save(p);

        session.save(b);

        session.save(p1);

        tx.commit();

        HibernateSessionFactory.closeSession();

    }

    

    //将product对象 查找出来

    public void query(){

        Session session=HibernateSessionFactory.getSession();

        Product p=(Product)session.get(Product.class, "4028d0814ec3de48014ec3de49950002");

        System.out.println(p.getPrice());

        Book b=(Book)p;

        System.out.println(b.getAuthor());

        HibernateSessionFactory.closeSession();

        

    }

    public static void main(String[] args) {

        CRUD crud=new CRUD();

//        crud.save2();

        crud.query();

    }

}

 

 

 

 

Hibernate笔记②--hibernate类生成表、id生成策略、级联设置、继承映射的更多相关文章

  1. Rhythmk 学习 Hibernate 03 - Hibernate 之 延时加载 以及 ID 生成策略

    Hibernate 加载数据 有get,跟Load 1.懒加载: 使用session.load(type,id)获取对象,并不读取数据库,只有在使用返回对象值才正真去查询数据库. @Test publ ...

  2. hibernate的持久化类、主键生成策略

    一.hibernate的持久化类 1.什么是持久化类: 持久化:将数据存储到关系型数据库. 持久化类:与数据库中的数据表建立了某种关系的java类.(持久化类=javabean+映射配置文件) 2.持 ...

  3. hibernate笔记--使用注解(annotation)方式配置单(双)向多对一的映射关系

    前面几篇都是介绍的用配置文件来实现实体类到数据库表的映射,这种方式是比较麻烦的,每一个pojo类都需要写一个相应的*.hbm.xml,无疑增加了很多代码量,不过也有优点就是利于维护,为了方便开发,Hi ...

  4. Hibernate笔记——Hibernate介绍和初次环境配置

    Hibernate简介 Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库. Hibernate ...

  5. Hibernate、Mybatis 通过数据库表反向生成java类和配置

    一.通过MyEclipse生成Hibernate类文件和hbm.xml文件,或者annotation文件    (转载孙宇老师的文章) 二.Mybatis生成实体类和配置文件: myeclipse下生 ...

  6. Hibernate学习笔记(八) — 懒载入与抓取策略

    懒载入(Load On Demand)是一种独特而又强大的数据获取方法,它可以在用户滚动页面的时候自己主动获取很多其它的数据,而新得到的数据不会影响原有数据的显示,同一时候最大程度上降低server端 ...

  7. 基于UUID生成短ID

    为什么需要短ID 数据库操作过程最常用到: 自增ID UUID 前者多数依赖Mysql的auto_increment,但数据移植麻烦. 如果是主从或主主,不同库里自增ID还可能不一致. 后者长度是个问 ...

  8. Hibernate学习笔记(三)Hibernate生成表单ID主键生成策略

    一. Xml方式 <id>标签必须配置在<class>标签内第一个位置.由一个字段构成主键,如果是复杂主键<composite-id>标签 被映射的类必须定义对应数 ...

  9. 使用hibernate利用实体类生成表和利用表生成实体类

    1,配置数据库,这里以oracle数据库为例.点击右侧Database图标:

随机推荐

  1. Devc++编程过程中的一些报错总结

    以下都是我在使用Devc++的过程中出现过的错误,通过查找资料解决问题,今天小小地记录.整理一下. 1.[Error] invalid conversion from 'const char*' to ...

  2. Scala的类继承

    Scala的类继承 extend Scala扩展类的方式和java一样使用extends关键字 class Employee extends Person { } 与java一样,可以在定义的子类重写 ...

  3. 20145207《Java程序设计》实验四( Android程序设计)实验报告

    <Java 程序设计>实验四( Android程序设计)实验报告 目录 改变 Android开发基础实验要求 实验成果 课后思考 改变 修改了之前仅仅是贴了图片,连代码都没粘的状态.增加了 ...

  4. python基础学习1-双层装饰器(实现登陆注册)

    LOGIN_USER = {"IsLogin":False} def check_login(func): #检查登陆的装饰器 def inner(*args,**kwargs): ...

  5. 一维码ITF 25简介及其解码实现(zxing-cpp)

    一维码ITF 25又称交插25条码,常用在序号,外箱编号等应用.交插25码是一种条和空都表示信息的条码,交插25码有两种单元宽度,每一个条码字符由五个单元组成,其中二个宽单元,三个窄单元.在一个交插2 ...

  6. Openstack入门篇(十八)之Cinder服务-->使用NFS作为后端存储

    1.安装cinder-volume组件以及nfs [root@linux-node2 ~]# yum install -y openstack-cinder python-keystone [root ...

  7. SSISDB2:SSIS工程的操作实例

    SSISDB 系列随笔汇总: SSISDB1:使用SSISDB管理Package SSISDB2:SSIS工程的操作实例 SSISDB3:Package的执行实例 SSISDB4:当前正在运行的Pac ...

  8. [webpack]--webpack 如何解析代码模块路径

    前言 webpack是如何解析代码模块路径 webpack 中有一个很关键的模块 enhanced-resolve 就是处理依赖模块路径的解析的,这个模块可以说是 Node.js 那一套模块路径解析的 ...

  9. C#简单的四位纯数字验证码

    验证码练手,整型.四位验证码 大体意思就是:四位纯数字验证,只要验证不成功就无限验证 刚开始在纠结怎么让整个过程循环起来,什么循环放到最外层,其实就是一个循环,看来自己的循环练习的还是不够多,不够灵活 ...

  10. spring4+springmvc+mybatis基本框架(app后台框架搭建一)

    前言: 随着spring 越来越强大,用spring4来搭建框架也是很快速,问题是你是对spring了解有多深入.如果你是新手,那么在搭建的过程中可以遇到各种各样奇葩的问题. SSM框架的搭建是作为我 ...