Hibernate注解开发示例
-------------------------------------------------------------------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注解开发示例的更多相关文章
- (转) Hibernate注解开发
http://blog.csdn.net/yerenyuan_pku/article/details/70162268 Hibernate注解开发 在Hibernate中我们一般都会使用注解,这样可以 ...
- Hibernate注解开发详解
*****************关于注解的简单介绍 详细介绍请点击这里注解详细教程 package com.tomowork.pojo; import org.hibernate.annotatio ...
- Hibernate注解开发、注解创建索引
1.注解的目的 简化繁琐的ORM映射文件(*.hbm)的配置 2.JPA和hibernate的关系 JPA:java persistence API,JPA注解是JavaEE的标准和规范. 两者的关系 ...
- Hibernate注解开发教程
目录 第一章 类级别注解 1-1 本章简介 一.Hibernate注解简介 二.JPA与Hibernate的关系 三.Hibernate注解的分类 1-2 准备工作 1-3 @Entity注解 1-4 ...
- Hibernate的应用与注解开发
Hibernate注解可以帮助我们大大简化hbm映射文件的配置,学习记录之. 先看示例: 1 package com.webShop.domain; 2 import java.io.Serializ ...
- 轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发(含CD光盘1张)
轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发(含CD光盘1张)(国家级奖项获奖作品升级版,四版累计印刷27次发行量超10万册的轻量级Jav ...
- Hibernate Validation使用示例及讲解
Hibernate Validation使用示例及讲解 时间 -- :: ITeye-博客 原文 http://wdmcygah.iteye.com/blog/2174680 主题 Java 在项目开 ...
- JPA注解开发
JPA注解开发 jpa是sun公司的一个ORM规范,只有接口和注解,没有具体实现. jpa是EJB3中的. 单表常用注解 书写注解,并配置 @Entity @Table(name = "c_ ...
- Hibernate 注解时 hibernate.hbm.xml的配置方法 以及与SSH整合里的配置方式
①纯Hibernate开发: 当你在Bean中写入注解后,需要告诉hibernate哪些类使用了注解. 方法是在hibernate.hbm.xml文件中配置 <!DOCTYPE hibernat ...
随机推荐
- linux输出之 printf 讲解--->与 echo 的区别
printf 你接触过printf没呢?? 如果你学了c语言的话你肯定就熟悉了,如果没有的话,不要急,,我保证你马上就会了! 我们来看一下案例: 这个可以看出来吧,echo输出的话会对文本换行哦,但是 ...
- 使用SVN进行源码管理
阅读目录: 1.SVN服务端配置 1.1 创建版本库 1.2 创建用户 1.3 设置用户权限 2.SVN客户端使用 2.1 向SVN服务器中导入源码 2.1.1 直接通过TortoiseSVN向SVN ...
- 【Linux】Linux下使用Docker快速部署Oracle数据库
安装最新Docker wget -qO- https://get.docker.com/ | sh` 安装 docker-compose sudo curl -L https://github.com ...
- C# 定制特性
一.初识特性 特性(attribute)是被指定给某一声明的一则附加的声明性信息. 设计类型的时候可以使用各种成员来描述该类型的信息,但有时候我们可能不太愿意将一些附加信息放到类的内部,因为这样,可能 ...
- Aspose.Words .NET如何实现文档合并的同页分页显示
当我们需要将一个文档添加到另一个文档时,经常会有不同的显示需求.为了文档的流畅,我们需要源文档和目标文档在内容上实现连续显示:而为了更好地区分文档,我们经常会希望两个文档的合并实现分页显示. 下面,就 ...
- 在 Azure Web 应用中创建 PHP 应用程序
本分步指南将通过 Azure Web 应用帮助您启动并运行示例 PHP 应用程序.除 PHP 外,Azure Web 应用还支持其他语言,如 Java..NET.Node.JS.Python.Ruby ...
- [Linq To Sql]解决join时的Collation冲突
背景 现在两表 A:
- MySQL8.0加载文件内容报错: ERROR 1148: The used command is not allowed with this MySQL version
mysql数据库将文件内容加载到表中报错: mysql> LOAD DATA LOCAL INFILE '/path/pet.txt' INTO TABLE pet LINES TERMINAT ...
- C#学习笔记12
1.在使用反射时,反射可以绕过安全访问级别(private.protected)修饰的类或属性,来获取需要的信息. 2.泛型的反射:可以使用Type.ContainsGenericParameters ...
- C# tcp udp 串口 通信
简单的实现tcp同步和异步,udp,串口通信 static List<TcpClientState> clientArray = new List<TcpClientState> ...