Clob:文本大对象,最长4G

Blob:二进制数据大对象,最长4G

util:

public class HibUtil {
  private static SessionFactory sessionFactory;
  static{
    //获取配置信息 hibernate.cfg.xml
    Configuration configuration = new Configuration().configure();
    //创建一个 ServiceRegistry的实例
    //首先获得其标准建造器,此处用了建造者模式 builder模式来创建对象
    //创建一个标准的构建器
    StandardServiceRegistryBuilder ssb = new StandardServiceRegistryBuilder();
    //建造(得到)ServiceRegistry的实例此处一定要传入//configuration.getProperties()否则会报错UnsupportedOperationException
    ServiceRegistry build = ssb.applySettings(configuration.getProperties()).build();
    //获得session工厂 一个数据库对应一个 SessionFactory
    sessionFactory = configuration.buildSessionFactory(build);
  }
  public static Session getSession(){
    return sessionFactory.openSession();
  }
  public static void main(String[] args) {
  }
}

hibernate.cfg.xml:

<!DOCTYPE hibernate-configuration PUBLIC
  "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
  "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
  <!-- 1:链接数据库的配置 -->
  <property name="hibernate.dialect">
    org.hibernate.dialect.Oracle10gDialect
  </property>
  <property name="hibernate.connection.driver_class">
    oracle.jdbc.driver.OracleDriver
  </property>
  <property name="hibernate.connection.username">scott</property>
  <property name="hibernate.connection.password">tiger</property>
  <property name="hibernate.connection.url">
    jdbc:oracle:thin:@localhost:1521:orcl
  </property>
  <!-- 2: 全局性配置 -->
  <property name="hibernate.show_sql">true</property>
  <property name="hibernate.format_sql">true</property>
  <!-- 仅供测试时使用 ,公司内禁止使用 -->
  <property name="hibernate.hbm2ddl.auto">update</property>
  <!-- 3: 映射文件的配置 -->
  <mapping resource="com/huawei/hib/po/Person.hbm.xml" />
</session-factory>
</hibernate-configuration>

po:

public class Address {
  private Integer addrId;
  private String addrName;
  public Integer getAddrId() {
    return addrId;
  }
  public void setAddrId(Integer addrId) {
    this.addrId = addrId;
  }
  public String getAddrName() {
    return addrName;
  }
  public void setAddrName(String addrName) {
    this.addrName = addrName;
  }
}

public class PersonName {
  private String firstName;
  private String lastName;
  public String getFirstName() {
    return firstName;
  }
  public void setFirstName(String firstName) {
    this.firstName = firstName;
  }
  public String getLastName() {
    return lastName;
  }
  public void setLastName(String lastName) {
    this.lastName = lastName;
  }
}

import java.sql.Blob;
import java.sql.Clob;

public class Person {
  private PersonName personName;
  private Integer age;
  private Clob txtObj;
  private Blob imgObj;
  private Address address;
  public PersonName getPersonName() {
    return personName;
  }
  public void setPersonName(PersonName personName) {
    this.personName = personName;
  }
  public Integer getAge() {
    return age;
  }
  public void setAge(Integer age) {
    this.age = age;
  }
  public Clob getTxtObj() {
    return txtObj;
  }
  public void setTxtObj(Clob txtObj) {
    this.txtObj = txtObj;
  }
  public Blob getImgObj() {
    return imgObj;
  }
  public void setImgObj(Blob imgObj) {
    this.imgObj = imgObj;
  }
  public Address getAddress() {
    return address;
  }
  public void setAddress(Address address) {
    this.address = address;
  }
}

Person.hbm.xml:

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
  "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
  "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping
  package="com.huawei.hib.po">
  <class name="Person" table="test_person" >
    <!-- 联合主键映射 -->
    <composite-id name="personName" class="PersonName">
      <key-property name="firstName" column="first_name" />
      <key-property name="lastName" column="last_name" />
    </composite-id>
    <property name="age" />
    <property name="txtObj" column="txt_Obj" />
    <property name="imgObj" column="img_Obj" />
    <!--组合关系映射 -->
    <component name="address" class="Address">
      <property name="addrId" column="addr_id" />
      <property name="addrName" column="addr_name" />
    </component>
  </class>
</hibernate-mapping>

dao:

public class PersonDao {
  public static void main(String[] args) throws FileNotFoundException {
    Session session = HibUtil.getSession();
    Address address = new Address();
    address.setAddrId(1);
    address.setAddrName("成都");
    PersonName personName = new PersonName();
    personName.setFirstName("三");
    personName.setLastName("张");
    Person p = new Person();
    p.setPersonName(personName);
    p.setAge(20);
    Blob imgObj = Hibernate.getLobCreator(session).createBlob(new FileInputStream("E:/123.jpg"),1200000);
    Clob txtObj = Hibernate.getLobCreator(session).createClob("成都是个美丽的地方");
    p.setTxtObj(txtObj);
    p.setImgObj(imgObj);
    p.setAddress(address);
    Transaction tx = session.beginTransaction();
    session.save(p);
    tx.commit();
    session.close();
  }
}

Hibernate 中 联合主键映射 组合关系映射 大对象映射(或者说文本大对象,二进制数据大对象)的更多相关文章

  1. hibernate里联合主键composite-id映射,查询单个主键的问题

    今天项目中遇到这个问题,搞了大半天,现在记录下来hibernate里联合主键配置(多个字段一起作为主键) <class name="com.cskj.hibernate.map.BbW ...

  2. hibernate 注解 联合主键映射

    联合主键用Hibernate注解映射方式主要有三种: 第一.将联合主键的字段单独放在一个类中,该类需要实现java.io.Serializable接口并重写equals和hascode,再将 该类注解 ...

  3. hibernate中基于主键映射1-1关联关系和基于外键映射1-1关联关系的不同

    基于主键映射1-1关联关系和基于外键映射1-1关联关系的不同,主要区别是在配置映射文件上会有区别 两个持久化类为Manager和Department 1:基于主键映射1-1关联关系 1)使用其他持久化 ...

  4. hibernate MTM 联合主键

    //适用于表里没有其他列,只有主键 //Course.java实体类 package com.tao.pojo; import java.util.HashSet; import java.util. ...

  5. Hibernate中的主键生成器generator

    本文讲述Hibernate的generator属性的意义.Generator属性有7种class,本文简略描述了这7种class的意义和用法. [xhtml] view plaincopy <c ...

  6. hibernate中复合主键的使用

    转: https://blog.csdn.net/shutingwang/article/details/6627730 https://blog.csdn.net/lmy86263/article/ ...

  7. Hibernate(5)—— 联合主键 、一对一关联关系映射(xml和注解) 和 领域驱动设计

    俗话说,自己写的代码,6个月后也是别人的代码……复习!复习!复习!涉及的知识点总结如下: One to One 映射关系 一对一单向外键(XML/Annotation) 一对一双向外键关联(XML/A ...

  8. hibernate 联合主键生成机制(组合主键XML配置方式)

    hibernate 联合主键生成机制(组合主键XML配置方式)   如果数据库中用多个字段而不仅仅是一个字段作为主键,也就是联合主键,这个时候就可以使用hibernate提供的联合主键生成策略. 具体 ...

  9. Java进阶知识05 Hibernate联合主键之Annotation(注解)和XML实现方式

    1.Hibernate联合主键(Annotation实现) 1.1.单列主键 1.1.1.为什么要有主键? //唯一确定一条记录    1.1.2.一个表能否有多个主键? //不能    1.1.3. ...

随机推荐

  1. 学hadoop需要什么基础

    最近一段时间一直在接触关于hadoop方面的内容,从刚接触时的一片空白,到现在也能够说清楚一些问题.这中间到底经历过什么只怕也就是只有经过的人才会体会到吧.前几天看到有个人问“学hadoop需要什么基 ...

  2. ES(1): Creat linux VM on Azure

    本章记录在ES集群之前的环境准备工作,主要包含的内容如下: 目录: 创建linux虚拟机 启用root用户 创建linux虚拟机 首先创建一个云服务 按向导创建云服务名称,如下 创建虚拟机, 第二步: ...

  3. CMSIS DSP Lib:RFFT函数的bug

    调用arm_rfft_fast_init_f32之后,还有两个成员需要初始化: arm_rfft_fast_instance_f32::pTwiddleRFFT = twiddleCoef_rfft_ ...

  4. C++进阶--const变量

    //############################################################# // const // - 编译时的限制:一个对象不能被修改 // in ...

  5. LNMP中常见的502错误及处理方法

    LNMP配置完成以后,经常遇到502 Bad Gateway的错误提示,究其原因多为2种.下面对这两方面的问题进行分析: 1. 配置方面的错误 配置错误中,或者因为php-fpm找不到路径,或者是权限 ...

  6. 跨域获取json数据

    原文地址:http://my.oschina.net/LinBandit/blog/34570   前阵子做了一个前端动态加载json数据的应用,其中使用xmlhttprequest动态加载js,但是 ...

  7. 032:基于Consul和MGR的MySQL高可用架构

    目录 一.Consul 1.Consul简介 2.准备环境 3.Consul 安装 4.Consul配置文件 5.Consul 服务检查脚本 6.Consul启动 二.MGR搭建 1.MGR配置 2. ...

  8. 【Codeforces】CF 2 B The least round way(dp)

    题目 传送门:QWQ 分析 求结尾0的数量QwQ. 10只能是$ 2 \times 5 $,我们预处理出每个数因子中2和5的数量. 我们接着dp出从左上到右下的经过的最少的2的数量和最少的5的数量.两 ...

  9. Apache Doris通过supervisor进行进程管理

    下面一段文字是摘自doris官方文档:注:在生产环境中,所有实例都应使用守护进程启动,以保证进程退出后,会被自动拉起,如 Supervisor.如需使用守护进程启动,需要修改各个 start_xx.s ...

  10. Elasticsearch 全文搜索和keyword search字段的mapping定义

    在ES5.0之前我们对于需要keyword search的字段都是这样定义的: { "field name":{ "type": "string&qu ...