-------------------------------------------------------------------customer-----------------------------------------------------------------------------------------------------------------------------

@Entity   /实体
@Table(name="t_customer")     //数据库表的名称,
public class Customer {
@Id      -------------主键
@GeneratedValue(strategy=GenerationType.IDENTITY)    //主键生成策略,自动增长
//@GenericGenerator(name="myuuid",strategy="uuid")    //代理主键为UUID时的操作
//@GeneratedValue(generator="myuuid")
private Integer id ;
private String name ;
@OneToMany(targetEntity=Order.class,mappedBy="c")  //目标实体, mappBy="c"代表外键的维护由对方也就是Order来维护.相当于inverse=true,这时如果保存客户时,级联保存订单.是可以的,但是不能维护外键,必须在代码中添加订单和客户的关系.
@Cascade(CascadeType.SAVE_UPDATE )     //
private Set<Order> orders = new HashSet<Order>() ;

-------------------------------------------------------------------Order----------------------------------------------------------------------------------------------------------------------------

@Entity  //实体
@Table(name="t_Order")  //数据库表的名称,数据库名在核心配置文件有,在这不用写.
public class Order {
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
private Integer id ;  //用引用类型,便于转换字符串,为空时返回值为null.
private Double money;
private String receiverInfo;
@ManyToOne(targetEntity=Customer.class)  //目标实体
@JoinColumn(name = "customer_id")     //指定外键列
private Customer c ;    //描述订单属于某一个客户

-------------------------------------------------------------------Test----------------------------------------------------------------------------------------------------------------------------

@Test
public void test01(){
//调用工具类,创建session.
Session session = HibernateUtils.openSession();
//开启事务
session.beginTransaction();
//创建
Customer c = new Customer();c.setName("wangwu");
Order o1 = new Order();o1.setMoney(1000.0); o1.setReceiverInfo("beijing");
Order o2 = new Order();o2.setMoney(1000.0);o2.setReceiverInfo("beijing");
//订单关联客户,保存订单时保存客户
//------------------------------------为了维护外键(要想显示外键必须写上)
o1.setC(c);o2.setC(c);
//session.save(o1);
//session.save(o2);
//客户关联订单,既保存客户时保存订单,为了进行级联操作
c.getOrders().add(o2); c.getOrders().add(o1);session.save(c);
//事务提交和session关闭
session.getTransaction().commit();
session.close();

-------------------------------------------------------------------hibernate.cfg.xml  ----------------------------------------------------------------------------------------------------------------------------

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> -----------configuration约束

<hibernate-configuration>

<session-factory>
<!-- 配置关于数据库连接的四个项 driverClass url username password -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql:///hibernatetest</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">123</property>

<!-- 设置连接提供者 -->
<property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
<!-- c3p0连接池的配置 -->
<property name="hibernate.c3p0.max_size">20</property> <!-- 最大连接池 -->
<property name="hibernate.c3p0.min_size">5</property> <!-- 最小连接数 -->
<property name="hibernate.c3p0.timeout">120</property> <!-- 超时 -->
<property name="hibernate.c3p0.idle_test_period">3000</property> <!-- 空闲连接 -->

<!-- 可以将向数据库发送的sql显示出来 -->
<property name="hibernate.show_sql">true</property>
<!-- 格式化sql -->
<property name="hibernate.format_sql">true</property>

<!-- hibernate的方言 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>

<!-- 自动创建表 -->
<property name="hibernate.hbm2ddl.auto">update</property>

<!-- 用于设置事务提交方式 -->
<property name="hibernate.connection.autocommit">false</property>

<!-- 配置hibernate的映射文件所在位置  如果用xml开发的话,Class换成resource-->
<mapping class="cn.itcast.domain.Customer" />
<mapping class="cn.itcast.domain.Order" />

</session-factory>

</hibernate-configuration>

-------------------------------------------------------------------删除操作 ----------------------------------------------------------------------------------------------------------------------------

@Test
public void test02(){
Session session = HibernateUtils.openSession();
session.beginTransaction();
//得到客户
Customer c = session.get(Customer.class, 2);
//得到订单
Order o = session.get(Order.class, 3);
//删除客户的订单
c.getOrders().remove(o);-------------------------------------在客户实体类的@OneTOMany括号里添加orphanRemoval=true
//session.delete(c);--------------------------------------------如果直接删除某个客户,在@OneTOMany下面使用hibernate提供的注解@cascade(CascadeType.delete)
//提交事务
session.getTransaction().commit();
session.close();
}

Hibernate注解开发示例的更多相关文章

  1. (转) Hibernate注解开发

    http://blog.csdn.net/yerenyuan_pku/article/details/70162268 Hibernate注解开发 在Hibernate中我们一般都会使用注解,这样可以 ...

  2. Hibernate注解开发详解

    *****************关于注解的简单介绍 详细介绍请点击这里注解详细教程 package com.tomowork.pojo; import org.hibernate.annotatio ...

  3. Hibernate注解开发、注解创建索引

    1.注解的目的 简化繁琐的ORM映射文件(*.hbm)的配置 2.JPA和hibernate的关系 JPA:java persistence API,JPA注解是JavaEE的标准和规范. 两者的关系 ...

  4. Hibernate注解开发教程

    目录 第一章 类级别注解 1-1 本章简介 一.Hibernate注解简介 二.JPA与Hibernate的关系 三.Hibernate注解的分类 1-2 准备工作 1-3 @Entity注解 1-4 ...

  5. Hibernate的应用与注解开发

    Hibernate注解可以帮助我们大大简化hbm映射文件的配置,学习记录之. 先看示例: 1 package com.webShop.domain; 2 import java.io.Serializ ...

  6. 轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发(含CD光盘1张)

    轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发(含CD光盘1张)(国家级奖项获奖作品升级版,四版累计印刷27次发行量超10万册的轻量级Jav ...

  7. Hibernate Validation使用示例及讲解

    Hibernate Validation使用示例及讲解 时间 -- :: ITeye-博客 原文 http://wdmcygah.iteye.com/blog/2174680 主题 Java 在项目开 ...

  8. JPA注解开发

    JPA注解开发 jpa是sun公司的一个ORM规范,只有接口和注解,没有具体实现. jpa是EJB3中的. 单表常用注解 书写注解,并配置 @Entity @Table(name = "c_ ...

  9. Hibernate 注解时 hibernate.hbm.xml的配置方法 以及与SSH整合里的配置方式

    ①纯Hibernate开发: 当你在Bean中写入注解后,需要告诉hibernate哪些类使用了注解. 方法是在hibernate.hbm.xml文件中配置 <!DOCTYPE hibernat ...

随机推荐

  1. (转)在 Windows 上调优 DB2 数据库的八个简单步骤

    原文:https://www.ibm.com/developerworks/cn/data/library/techarticle/dm-1209tunedb2/index.html 概述 为了更好地 ...

  2. (转)Linux SSH批量分发管理

    Linux SSH批量分发管理 原文:http://blog.51cto.com/chenfage/1831166 第1章 SSH服务基础介绍 1.1 SSH服务 1.1.1SSH介绍 SSH是Sec ...

  3. Coursera 机器学习 第6章(上) Advice for Applying Machine Learning 学习笔记

    这章的内容对于设计分析假设性能有很大的帮助,如果运用的好,将会节省实验者大量时间. Machine Learning System Design6.1 Evaluating a Learning Al ...

  4. sqlserver 限制用户只能访问指定的视图

    项目中有一个需求,要求给其它单位提供数据,我们用到了视图,并要求不能让他们看到数据库中的其它数据,我们为其创建了单独的账号,并只能看到指定视图 一.创建视图 CREATE VIEW [dbo].[v_ ...

  5. 【Linux相识相知】任务计划和周期性任务

    在我们的生活中,有的工作是例行的,例如每年一次加薪.每年给女朋友过一次生日.每天上班都要打卡等,有的工作是临时发生的,例如明天朋友要来访,你需要准备午餐等等. 像很多例行的工作,你一旦忙起来就很容易忘 ...

  6. React之特点及常见用法

    1.什么是React? React是一个用于构建用户界面的JavaScript库.主要用于构建UI,很多人认为Reatc是MVC中的V(视图). React起源于Facebook的内部项目,用来架构I ...

  7. select操作大全

    每一次操作select的时候,总是要出来翻一下资料,不如自己总结一下,以后就翻这里了. 比如<select class="selector"></select&g ...

  8. python-requests 简单实现数据抓取

    安装包: requests,lxmlrequest包用于进行数据抓取,lxml用来进行数据解析对于对网页内容的处理,由于html本身并非如数据库一样为结构化的查询所见即所得,所以需要对网页的内容进行分 ...

  9. ArcGIS Enterprise 10.5.1 静默安装部署记录(Centos 7.2 minimal)- 4、安装 ArcGIS for Server

    安装ArcGIS for Server 解压server安装包,tar -xzvf ArcGIS_Server_Linux_1051_156429.tar.gz 切换到arcgis账户静默安装serv ...

  10. js 常用排序整理

    排序: 1. 内部排序: (1). 交换排序: 1). 冒泡排序 稳定 一次比较相邻两个元素的大小,顺序错误的,将其位置互换 (从高位到低位 或者 从低位到高位) 初始版: var array = [ ...