@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. BZOJ 4524(贪心+二叉堆)

    题面 若一个大于 11 的整数 M的质因数分解有 k 项,其最大的质因子为 \(a_k\),并且满足 \({a_k}^k \leq N,k<128\),我们就称整数 M 为 N-伪光滑数. 现在 ...

  2. FZU 2059 MM

    Description There is a array contain N(1<N<=100000) numbers. Now give you M(1<M<10000) q ...

  3. android Manifest.xml 文件详解

  4. face_recognition人脸识别框架

    一.环境搭建 1.系统环境 Ubuntu 17.04 Python 2.7.14 pycharm 开发工具 2.开发环境,安装各种系统包 人脸检测基于dlib,dlib依赖Boost和cmake $ ...

  5. wpf 查找控件

    public List<T> GetChildObjects<T>(DependencyObject obj, Type typename) where T : Framewo ...

  6. IPv6 关于路由器配置静态IPv6路由的命令

    今天在学习路由器配置ipv6 的时候遇到了一点疑惑 一条命令为:ipv6 route FE80:0202::/32 serail 0/1 201 一条命令为:ipv6 route FE80:0202: ...

  7. 代码解释n |= n >>> 16

    public static int nextPowerOf2(int n) {n -= 1;n |= n >>> 16;n |= n >>> 8;n |= n &g ...

  8. 开发react 应用最好用的脚手架 create-react-app

    安装 npx create-react-app my-app cd my-app npm start 安装后之后,就是这样的了 配置 这样的”零配置”没法满足我们的需求,我们需要自定义,需要加一些 l ...

  9. python 发送请求

    data = {"a":1,"b":2} urllib2 get: get_data = urllib.urlencode(data) req_url = UR ...

  10. codeblocks编译调试C语言二级指针小记

    夜已深,暂时附上一个截图,后面慢慢道来. 下图时用codeblocks调试C语言的界面,codeblocks版本是17.12nosetup版,也为继承mingw,我用的编程器是tdm-gcc-5.1. ...