[记录]JPA双向关联一对多

参考资料JPA双向关联多对一映射

-- Table: works_base

-- DROP TABLE works_base;

CREATE TABLE works_base
(
  authorid integer,//fk
  id integer,//pk
  name character varying(80)
)
WITH (
  OIDS=FALSE
);
ALTER TABLE works_base
  OWNER TO jincheng;

-- Table: author_base

-- DROP TABLE author_base;

CREATE TABLE author_base
(
  id integer,//pk 
  name character varying(80),
  mail character varying(80)
)
WITH (
  OIDS=FALSE
);
ALTER TABLE author_base
  OWNER TO jincheng;
下面是entity的写法,使用注释

package com.jincheng.ssh.model;

import java.io.Serializable;
import java.lang.Integer;
import java.lang.String;
import javax.persistence.*;
import static javax.persistence.FetchType.EAGER;
import static javax.persistence.FetchType.LAZY;

/**
 * Entity implementation class for Entity: WorksBase
 *
 */
@Entity
@Table(name="works_base")
public class WorksBase implements Serializable {

	   
	@Id
	@Column(name="id")
	private Integer id;
	@Column(name="name")
	private String name;
	@ManyToOne(cascade=CascadeType.ALL)
	@JoinColumn(name="authorid")
	private AuthorBase authorBase;//使用authorBase代替了authorid
	private static final long serialVersionUID = 1L;

	public WorksBase() {
		super();
	}   
	public Integer getId() {
		return this.id;
	}

	public void setId(Integer id) {
		this.id = id;
	}   
	public String getName() {
		return this.name;
	}

	public void setName(String name) {
		this.name = name;
	}
   
}

package com.jincheng.ssh.model;

import java.io.Serializable;
import java.lang.Integer;
import java.lang.String;
import java.util.Set;

import javax.persistence.*;


/**
 * Entity implementation class for Entity: AuthorBase
 *
 */
@Entity
@Table(name="author_base")
public class AuthorBase implements Serializable {

	@Id
	@Column(name="id")
	private Integer id;
	@Column(name="name")
	private String name;
	@Column(name="mail")
	private String mail;
	@OneToMany(mappedBy="authorBase")
	private Set<WorksBase> worksBases;
	private static final long serialVersionUID = 1L;

	public AuthorBase() {
		super();
	}   
	public Integer getId() {
		return this.id;
	}

	public void setId(Integer id) {
		this.id = id;
	}   
	public String getName() {
		return this.name;
	}

	public void setName(String name) {
		this.name = name;
	}   
	public String getMail() {
		return this.mail;
	}

	public void setMail(String mail) {
		this.mail = mail;
	}
   
}
代码中红色标记部分:一个mappedBy和JoinColumn, 就是告诉JPA实现者, worksBases是通过 WorksBase里的 authorBase映射得到,每次查找 worksBases是通过 WorksBase里的 authorBase联接


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
此扩展程序可以在WorkBase MEET功能中共享屏幕。 在MEET功能中使用屏幕共享功能之前,您必须创建一个WorksBase帐户。请访问worksbase.com了解更多信息。 关于WORKSBASE WorksBase是您日常业务运营的基地。它提供了一个可定制的虚拟工作区,其中包含多个内置工具,并能够集成经常使用的应用程序和内容。从任何浏览器或设备登录到您的WorksBase。 - 简单的会议 MEET功能集成了视频和网络会议功能,可以通过简化的用户界面将任何设备的团队联系在一起。按需使用您的首选会议应用程序满足需求或安排未来的会议。使用虚拟白板在会议期间进行协作和头脑风暴,共享文档和聊天。 - 工作流自动化 计划和管理功能允许您使用清单和表单创建简单的业务流程工作流程。它预先配置上游,中游和下游操作,以消除昂贵的实施的需要。专为最终用户而不是IT人员设计,所以定制是一件轻而易举的事情。 - 文件管理 SHARE功能可让您在需要时访问信息。从任何设备访问和共享内部和外部协作者的安全文件。随着文件到期,只读/不保存共享,注释和移动访问,Share工具超越标准的云存储解决方案。 - 非现场协助 ASSIST快速连接办公室和现场团队,以改善质量控制和EHS事件管理。基于可穿戴技术,ASSIST为现场工作人员提供了一种免提方式,通过实时视频流传输信息到办公室和从办公室传输信息。一种高效和低成本的异地协助解决方案 - 消除纸张 从卡车票和需要处理的井信息到无数传入发票,TRANSFORM从各种格式捕获数据并将其提供给适当的系统。这个工具在每次使用时变得更加智能,使自动化和连接系统更容易实现。 我们的使用条款: https://psg.hitachi-solutions.com/legal/terms-of-use 支持语言:English (United States)

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值