@Entity ,注册在类头上,将一个类声明为一个实体bean(即一个持久化POJO类) 。
@Table ,注册在类头上,注解声明了该实体bean映射指定的表(table)。
@Id用来注册主属性,@GeneratedValue用来注册主属性的生成策略,@Column用来注册属性,@Version用来注册乐观锁,@Transient用来注册不是属性。
以上的@Id、@GeneratedValue、 @Column 、 @Version,可以用来注册属性,既可以写在Java类的属性上,也可以注册在属性对应的getter上。
@Transient注册在多余的属性或多余的getter上,但是必须与以上的@Column等对应。
@Column
标识属性对应的字段,示例:@Column(name=“userName")

java代码:

  1. @Column(
  2. )
  3. )
  4. )
  5. )
  6. )
  7. )
  8. )
  9. )
  10. ; // decimal precision   (9)
  11. ; // decimal scale           (10)

(1) name 可选,列名(默认值是属性名)
(2) unique 可选,是否在该列上设置唯一约束(默认值false)
(3) nullable 可选,是否设置该列的值可以为空(默认值false)
(4) insertable 可选,该列是否作为生成的insert语句中的一个列(默认值true)
(5) updatable 可选,该列是否作为生成的update语句中的一个列(默认值true)
(6) columnDefinition 可选: 为这个特定列覆盖SQL DDL片段 (这可能导致无法在不同数据库间移植)
(7) table 可选,定义对应的表(默认为主表)
(8) length 可选,列长度(默认值255)
(8) precision 可选,列十进制精度(decimal precision)(默认值0)
(10) scale 可选,如果列十进制数值范围(decimal scale)可用,在此设置(默认值0)
@Id,标识这个属性是实体类的唯一识别的值。
注意:这个注解只能标注单一列构成的主键,如tbl_grade那种有两个字段组成的联合主键由其他注解标识。
回忆*.hbm.xml:
<id name=
 
"uuid">
     <generator class=
 
"assigned"/>
</id>
@Id,只是标识这个属性是主键,但是并没有指出其生成策略,如上例中的assigned就是由程序员指定的生成策略。
如果仅仅写出@Id,即是使用assigned生成略,如:

java代码:

  1. @Id
  2. @Column
  3. private int uuid;
  4. 如果想使用Oracle支持的sequence取主键,必须通过@GeneratedValue来指定生成策略,而由@SequenceGenerator指定如何使用sequence。
  5. @Id
  6. @Column
  7. @GeneratedValue(
  8. strategy = GenerationType.SEQUENCE,//使用sequence生成主键
  9. generator =“generator“//引用下面名为gernator的生成策略
  10. )
  11. @SequenceGenerator(
  12. name = “generator”,//定义名为generator的生成策略
  13. ,//每次sequence加1
  14. name=“seq_a”//引用名为seq_a的sequence
  15. )
  16. private int uuid;
  17. @Version

标识这个属性用来映射乐观锁的version
@Transient
标识这个属性不用持久化
@Embeddable【小对象的头上】
标识实体中可以定义一个嵌入式组件(embedded component)。组件类必须在类一级定义@Embeddable注解。
注意:如果这个小对象作为复合主键,一定要实现Serializable接口。这并不是注解决定的,而是Hibernate的主键都需要实现Serializable接口。
@EmbeddedId 【大对象的属性头上】
引用定义的小对象作为主键。
注意:不需要再使用@Id注解。
 

标准的1:1
 
 
 
XML的配置

java代码:

  1. 【tbl_product】:
  2. <one-to-one name="info" cascade="all"/>
  3. 【tbl_product_info】:
  4. <id name="uuid">
  5. <generator class=“foreign【写死,使用外来生成策略】">
  6. <param name=“property”>product【引用自己的Java属性名】</param>
  7. </generator>
  8. </id>
  9. <one-to-one name="product"/>

注解的配置

java代码:

  1. 【tbl_product】:
  2. @OneToOne(cascade=CascadeType.ALL)
  3. @PrimaryKeyJoinColumn
  4. private ProductInfoModel info;
  5. 【tbl_product_info】:
  6. @Id
  7. @Column
  8. @GeneratedValue(generator=“copy【引用生成策略】")
  9. @GenericGenerator(name=“copy【定义生成策略】”,strategy=“foreign【写死,使用外来策略】”,parameters=@Parameter(name=“property”,value=“product【引用自己的Java属性】"))
  10. private int uuid;
  11. @OneToOne(mappedBy=“info【引用对方的Java属性】")
  12. private ProductModel product;

标准的1:M
  
XML的配置
 

java代码:

  1. 【tbl_parent】:
  2. <set name="children">
  3. <key column=“puuid【对方的数据库外键列名】"/>
  4. <one-to-many class=“cn.javass.model.c.ChildModel【对方的Java类名】"/>
  5. </set>
  6. 多【tbl_child】:
  7. <many-to-one name=“parent” column=“puuid【自己的数据库外键列名】"/>

注解的配置
 

java代码:

  1. 【tbl_parent】:
  2. @OneToMany
  3. @JoinColumn(name="puuid【对方的数据库外键列名】")
  4. private Set<ChildModel> children = new HashSet<ChildModel>();
  5. 多【tbl_child】:
  6. @ManyToOne
  7. @JoinColumn(name="puuid【自己的数据库外键列名】")
  8. private ParentModel parent;

标准的1:M
 
 
XML的配置

java代码:

  1. <set name=“courses” table=“tbl_grade【联接表】">
  2. <key column=“suuid【联接表里代表自己的数据库字段名】"/>
  3. <many-to-many column=“cuuid【联接表里代表对方的数据库字段名】class=“cn.javass.model.e.CourseMode【对方的类名】"/>
  4. </set>
  5. 注解的配置
  6. @ManyToMany
  7. @JoinTable(
  8. name=“tbl_grade【联接表】",
  9. joinColumns=@JoinColumn(name="suuid【联接表里代表自己的数据库字段名】"),
  10. inverseJoinColumns=@JoinColumn(name="cuuid 【联接表里代表对方的数据库字段名】” )
  11. )
  12. private Set<CourseModel> courses = new HashSet<CourseModel>();

标准的1:M
 
 
 
 
XML的配置
 

java代码:

  1. 【tbl_product】:
  2. <one-to-one name=“info” foreign-key=“puuid【对方的数据库外键列名】" cascade="all"/>
  3. 【tbl_product_info】:
  4. <many-to-one name=“product” column=“puuid【自己的数据库外键列名】” unique=“true【写死】"/>

注解的配置
 

java代码:

  1. 【tbl_product】:
  2. @OneToOne(cascade=CascadeType.ALL,mappedBy=“product【对方的Java类属性名 】")
  3. private ProductInfoModel info;
  4. 【tbl_product_info】:
  5. @OneToOne
  6. @JoinColumn(name=“puuid【自己的数据库外键列名】")
  7. private ProductModel product;

标准的1:M
 
 
 
 
 
XML的配置

java代码:

  1. 【tbl_parent】:
  2. <set name=“children” table=“tbl_parent_child【联接表】">
  3. <key column=“puuid【联接表里代表自己的数据库列名】"/>
  4. <many-to-many column=“cuuid【联接表里代表对方的数据库列名】” unique=“true【写死】”
  5. class=“cn.javass.model.d.ChildModel【对方的Java类名】"/>
  6. </set>
  7. <join table=“tbl_parent_child【联接表】">
  8. <key column="cuuid【联接表里代表自己的数据库列名】"/>
  9. <many-to-one name="parent" column="puuid【联接表里代表对方的数据库列名】" unique="true【写死】"/>
  10. </join>

注解的配置

java代码:

  1. 【tbl_parent】:
  2. @OneToMany(mappedBy="parent【对方的Java类属性名 】")
  3. private Set<ChildModel> children = new HashSet<ChildModel>();
  4. 多【tbl_child】:
  5. @ManyToOne
  6. @JoinTable(
  7. name=“tbl_parent_child【联接表】",
  8. joinColumns=@JoinColumn(name="cuuid【联接表里代表自己的数据库字段名】"),
  9. inverseJoinColumns=@JoinColumn(name="puuid【联接表里代表对方的数据库字段名】")
  10. )
  11. private ParentModel parent;

 
标准的1:M
 
 
 
 
 
XML的配置

java代码:

  1. 【tbl_product】:
  2. <join table=“tbl_product_relation【联接表】">
  3. <key column=“puuid【联接表里代表自己的列名】"/>
  4. <many-to-one name=“course【自己的Java属性名】” column=“cuuid【联接表里代表对方的列名】” unique=“true【写死】"/>
  5. </join>

注解的配置

java代码:

  1. 【tbl_product】:
  2. @ManyToOne
  3. @JoinTable(
  4. name=" tbl_product_relation 【联接表】",
  5. joinColumns=@JoinColumn(name="suuid【联接表里代表自己的列名】"),
  6. inverseJoinColumns=@JoinColumn(name="cuuid【联接表里代表对方的列名】",unique=true【写死】)
  7. )
  8. private CourseModel course;

 
 

Hibernate4之注解零配置的更多相关文章

  1. Spring 基于注解零配置开发

    本文是转载文章,感觉比较好,如有侵权,请联系本人,我将及时删除. 原文网址:< Spring 基于注解零配置开发 > 一:搜索Bean 再也不用在XML文件里写什么配置信息了. Sprin ...

  2. Spring3+SpingMVC+Hibernate4全注解环境配置

    Spring3+SpingMVC+Hibernate4全注解环境配置 我没有使用maven,直接使用Eclipse创建动态Web项目,jar包复制在了lib下.这样做导致我马上概述的项目既依赖Ecli ...

  3. struts 多文件上传 annotation注解(零配置)+ ajaxfileupload + 异步 版本

    [本文简介] struts 多文件上传.基于”零配置“+"ajaxfileupload" 的一个简单例子. [导入依赖jar包] jquery-1.7.2.js : http:// ...

  4. Struts2 注解零配置方法(convention插件使用)

    最近接触到一个新的项目,是做一个使用S2SH的电子商务商城的二次开发.之前使用过S2SH,在此之前的项目中,Struts2 使用的是XML配置而这个项目是使用注解.在这个项目中,注解还不需要使用Act ...

  5. Spring3注解零配置

    我们在以前学习 Spring 的时候,其所有的配置信息都写在 applicationContext.xml 里,大致示例如下: java代码: 查看复制到剪贴板打印     OracleDriver& ...

  6. Spring学习笔记(14)——注解零配置

    我们在以前学习  Spring  的时候,其所有的配置信息都写在  applicationContext.xml  里,大致示例如下: java代码: <beans> <bean n ...

  7. spring+hibernate+struts2零配置整合

    说句实话,很久都没使用SSH开发项目了,但是出于各种原因,再次记录一下整合方式,纯注解零配置. 一.前期准备工作 gradle配置文件: group 'com.bdqn.lyrk.ssh.study' ...

  8. struts2 Convention插件零配置,使用注解开发

    从struts21开始,struts2不再推荐使用codebehind作为零配置插件,而是改用Convention插件来支持零配置.与以前相比较,Convention插件更彻底. 使用Conventi ...

  9. 8 -- 深入使用Spring -- 4...5 AOP代理:基于注解的“零配置”方式

    8.4.5 基于注解的“零配置”方式 AspectJ允许使用注解定义切面.切入点和增强处理,而Spring框架则可识别并根据这些注解来生成AOP代理.Spring只是使用了和AspectJ 5 一样的 ...

随机推荐

  1. vue基础学习一

    写一个例子,告诉你VUE的方便之处,就是双向绑定,不需要操作DOM对象,而是操作数据 div中msg 和JS中msg是一一对应的 然后看浏览器中 然后如果我想改变浏览器中值,我在console这么操作 ...

  2. __str__和__repr__的区别

    有时候我们想让屏幕打印的结果不是对象的内存地址,而是它的值或者其他可以自定义的东西,以便更直观地显示对象内容,可以通过在该对象的类中创建或修改__str__()或__repr__()方法来实现(显示对 ...

  3. USACO 2014 US Open Odometer /// 数位DP

    题目大意: 给定区间 l r 求得区间中有多少个数 数的各个数位里出现最多次的数>=数的长度的一半 如2233 3334 枚举k在数中出现次数在一半以上 那么求出的所有方案数中应该减去 两个数各 ...

  4. SPI、IIC、IIS、UART、JTAG的应用场合级区别

    SPI  SPI接口的全称是"Serial Peripheral Interface",意为串行外围接口,是Motorola首先在其MC68HCXX系列处理器上定义的. SPI接口 ...

  5. SpringMVC学习(11):表单标签

    本篇我们来学习Spring MVC表单标签的使用,借助于Spring MVC提供的表单标签可以让我们在视图上展示WebModel中的数据更加轻松. 一.首先我们先做一个简单了例子来对Spring MV ...

  6. top查看进程的参数

    top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器. top显示系统当前的进程和其他状况,是一个动态显示过程,即可以通过用户按键来不 ...

  7. linux下有趣的工具

    1.toilet(在CentoOS7 安装) yum install -y https://raw.githubusercontent.com/sliqua-hosting/repo/master/c ...

  8. C++中static的作用

    tatic关键字有俩作用:(1).控制存储分配:(2).控制一个名字的可见性和连接.   随着C++名字空间的引入,我们有了更好的,更灵活的方法来控制一个大项目的名字增长.     在类的内部使用st ...

  9. python模块打补丁

    先自定义两个模块,然后,我们调用模块时,用打补丁方式,改写mod_1.py模块.为mod_2.py内容:其实这就相当于,在不改动mod_1.py模块的前提下,打上补丁. 写这个主要是gevent协程的 ...

  10. 一次CTS引发的网络故障

    接到业务部门通知,A机房(库a)到B机房(库b)之间的数据库服务器之间的网络带宽异常突增,影响公司对外业务的整体带宽.一接到通知,作为数据库管理对所涉及的IP还是比较敏感.第一反应就是可能当时主库产生 ...