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. plink:将bed文件转化为ped,map文件

    用--recode命令,--out表示转化的文件的名字,本例已经命名为“filter” /plink-1.07-x86_64/plink --bfile filter --recode --out f ...

  2. 用nodej和glub-watcher写的监听go 项目自动编译,很鸡肋

    glub 一般都是很轻量的编译. go太重了,改一小个部分,就编译的话,多数是编译失败. 而且很消耗性能,还没想到完美的优化办法. 暂时用个定时器 监听2秒,停止1秒,如此循环,会减少些 “无效”的编 ...

  3. spring mvc 配置文件信息记录

    <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...

  4. c# 程序检测日志输出的类

    public class LogWrite     {         public LogWrite()         {             //             // TODO:  ...

  5. FreeBSD_11 - 系统管理——{ Part_5 - ZFS }

    参考資料 http://docs.oracle.com/cd/E37934_01/html/E36658/toc.html https://www.freebsd.org/doc/en_US.ISO8 ...

  6. 转自知乎:GitHub基本功能

    作者:Fadeoc Khaos 链接:https://www.zhihu.com/question/20070065 来源:知乎 著作权归作者所有Github的基本功能: Repository:你和我 ...

  7. Oracle每天自学一点点 常用Oracle

    创建表空间:create tablespace crmtb datafile 'F:\Oracle\oradata\crmtb.dbf' size 100M;删除表空间:DROP TABLESPACE ...

  8. 使用multipart请求处理文件上传

    在开发Web应用程序时比较常见的功能之一,就是允许用户利用multipart请求将本地文件上传到服务器,而这正是Grails的坚固基石——Spring MVC其中的一个优势.Spring通过对Serv ...

  9. 获得select下拉框的值

    html -------------------------------------------------------------------------------------- <sele ...

  10. centos下安装iftop

    CentOS 下iftop 的安装 安装方法一:编译安装(安装成功) wget http://ex-parrot.com/~pdw/iftop/download/iftop-0.17pre3.tar. ...