atitit.atitit.hb many2one relate hibernate 多对一关联配置..

1. 多对一单向 @ManyToOne 1

1. 其中@JoinColumn 注解 2

2. @targetEntity注解 2

2. 生成的sql LEFT OUTER 2

3. 多对一也可以通过关联表的方式来映射,通过 @JoinTable 注解可 2

4. 另外一个属性也关联到table column(recomn?? ) 3

5. 参考 3

1. 多对一单向 @ManyToOne

(数据库设计,多在在多方设计外键)

数据库设计:主键列不可分,联合主键不可有部分依赖,不能存在传递依赖

注解中在多方的类中加入一个"一方"的类,然后在get方法之上加上@ManyToOne

作者:: 老哇的爪子 Attilax 艾龙,  EMAIL:1466519819@qq.com

转载请注明来源: http://blog.csdn.net/attilax

·     @ManyToOne(cascade=   {CascadeType.PERSIST,CascadeType.MERGE},targetEntity= CompanyImpl.class)

·    @JoinColumn(name="COMP_ID")

·    public Company getCompany() {

·      return company;

·    }

·    ...

·

1. 其中@JoinColumn 注解

· 是可选的,关键字段默认值和一对一关联的情况相似。列名为:主题的关联属性名 + 下划线 + 被关联端的主键列名。本例中为company_id,因为关联的属性是company, Company的主键为 id.

· creator_ID   %属性名称%_主键列名(not cls property name)

· 要是不能coc,要设置此注解.

·

2. @targetEntity注解

· 有个targetEntity属性,该参数定义了目标实体名。通常不需要定义,大部分情况为默认值。但下面这种情况则需要 targetEntity 定义(使用接口作为返回值,而不是常用的实体)。

·  ...

·

2. 生成的sql LEFT OUTER

FROM

gv_material gvmaterial0_

LEFT OUTER JOIN t_user_users tuserusers1_ ON gvmaterial0_.create_user = tuserusers1_.ID

3. 多对一也可以通过关联表的方式来映射,通过 @JoinTable 注解可

· 定义关联表。该关联表包含指回实体的外键(通过@JoinTable.joinColumns)以及指向目标实体表的外键(通过@JoinTable.inverseJoinColumns).

·

· @Entity()

· public class Flight implements Serializable {

·

·    @ManyToOne( cascade = {CascadeType.PERSIST, CascadeType.MERGE} )

·    @JoinTable(name="Flight_Company",

·        joinColumns = @JoinColumn(name="FLIGHT_ID"),

·        inverseJoinColumns = @JoinColumn(name="COMP_ID")

·    )

·    public Company getCompany() {

·        return company;

·    }

·    ...

· }

·

4. 另外一个属性也关联到table column(recomn?? )

Jonjye nen single test l ...

insertable = false:该外键列不出现在INSERT语句里面

updatable = false:该外键列不出现在UPDATE语句里面

这种用法最常见的情况就是这个类里面有另外一个属性直接关联到一个外键:

@Column(name="USER_ID")

Long user_id;

@OneToMany

@JoinColumn(name = "USER_ID", insertable = false,updatable = false)

User user;

5. 参考

hibernate注解 - java - ITeye技术网站.htm

使用Hibernate注解来配置多对一单向的三种方法_Saminar2012_新浪博客.htm

atitit.atitit.hb many2one relate hibernate 多对一关联配置..的更多相关文章

  1. hibernate多对多关联映射

    关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...

  2. 05.Hibernate多对多关联

        前言:本文讲解使用Hibernate映射多对多关联关系,并使用多种方式映射多对多关联. 1.数据库表的多对多关系     本文根据学生信息表(tb_student)和教师信息表(tb_teac ...

  3. Hibernate多对多关联

    多对多关联: 示例:Teacher和Student,一个Teacher可以教很多student,一个Student也可以被很多teacher教   多对多单向关联 Teacher知道自己教了哪些学生, ...

  4. hibernate多对多关系配置

    一.创建用户,角色实体类. 一名用户可以有多个角色.一个角色可以对于多名用户. 用户实体类 public class User { private int uId; private String uN ...

  5. Hibernate 多对多关联映射, 中间表加查询条件

    package com.coracle.yk.xpo.po.base; import java.util.Date; import java.util.HashSet; import java.uti ...

  6. Hibernate 多对多关联Demo

    以学生[Student ]与课程[Course ]之间的关系为例: //Course .java public class Course implements Serializable { priva ...

  7. Hibernate多对多关联映射的HQL中的in条件查询问题

    群里有朋友求解一个问题,高分求一条HQL多对多查询语句 . 问题描述见 http://topic.csdn.net/u/20090621/16/4eac6fe0-bf3e-422e-a697-f758 ...

  8. Hibernate 多对一关联查询

     版权声明:本文为博主原创文章,如需转载请标注转载地址.  博客地址:http://www.cnblogs.com/caoyc/p/5598269.html  一.单向多对一和双向多对一的区别 如果只 ...

  9. hibernate 多对一关联

    (转自尚学堂教学内容)   注解多对一: package com.bjsxt.hibernate; import javax.persistence.Entity; import javax.pers ...

随机推荐

  1. stm32 MDK5软件仿真之查看io口输出

    软件MDK5 stm32的pack     打开MDK,添加工程 一.首先找到Project的Options选项,里面的Debug选为Use Simulator,也就是选择软件仿真. 然后再Logic ...

  2. 2.1 LibCurl编程流程(转)

    转载地址:http://blog.chinaunix.net/u/17660/showart_1822514.html2 LibCurl编程2.1 LibCurl编程流程在基于LibCurl的程序里, ...

  3. Json在前台与后台之间的使用

     一.将前台数据,使用ajax中的post.get传到后台 $.ajax({ type: 'post', url: 'your url', data: $("form").seri ...

  4. 在UITableViewStylePlain情况下sectionHeader可以与tableview一起滑动的解决方法

    -(void)scrollViewDidScroll:(UIScrollView *)scrollView { CGFloat sectionHeaderHeight = ; ) { scrollVi ...

  5. Caffe(卷积神经网络框架)介绍

    Caffe(卷积神经网络框架)Caffe,全称Convolution Architecture For Feature Extraction caffe是一个清晰,可读性高,快速的深度学习框架.作者是 ...

  6. php 中文正则

    utf8编码中文 preg_match("/^[\x{4e00}-\x{9fa5}]+$/u") 而不是 "/^[\x4e00-\x9fa5]+$/u"

  7. Web前台直接加载GIS格式数据分析

    本文以Flex直接加载Shp.DWG和MDB为例. 首先看一份现估测数据: 1)  加载Shp文件,目前直接由前台Flex代码完成: 图1 在ArcCatalog里面的Shp文件 图2 直接在前台加载 ...

  8. 「2013-9-14」Change Remote Desktop Port

    修改远程桌面服务(Remote Desktop Service)的端口号,有几点原因: 默认是 3389 端口,也是经常被端口嗅探器扫描的一个端口.更换端口号,一定程度上可以带来更好的安全性. 如果一 ...

  9. delphi平方开方

    用delphi自带的sqr和sqrt函数 procedure TForm2.SpeedButton3Click(Sender: TObject); begin ShowMessage(Sqr(6).T ...

  10. 从0开始学Swift笔记整理(二)

    这是跟在上一篇博文后续内容: --函数中参数的传递引用 类是引用类型,其他的数据类型如整型.浮点型.布尔型.字符.字符串.元组.集合.枚举和结构体全部是值类型. 有的时候就是要将一个值类型参数以引用方 ...