JPA中的ManyToOne和OneToMany

 

概念说明

一个用户可以有多个手机,一个手机只能被一个用户使用。这个就是多对一的关系,或者称之为一对多。用户是一,手机是多。外键设置在多这一方(如果不懂,可以百度一下)。具体设置的表如下: objectrelational-manytoone2 EMPLOYEE (table)
EMP_IDFIRSTNAMELASTNAMESALARYMANAGER_ID
1BobWay500002
2SarahSmith75000null
PHONE (table)
IDTYPEAREA_CODEP_NUMBEROWNER_ID
1home613792-00001
2work613896-12341
3work416123-44442
一定要设置ManyToOne,如果需要可以设置OneToMany。

ManyToOne设置

设置ManyToOne的具体方法如下:
@Entity
public class Phone {
  @Id
  private long id;
  ...
  @ManyToOne(fetch=FetchType.LAZY)
  @JoinColumn(name="OWNER_ID")
  private Employee owner;
  ...
}
具体说明: fetch=FetchType.LAZY的意思是select的时候懒加载,当加载phone这个对象的时候,会加载他的属性,如id,firstname,lastname,但是不会去加载owner的属性。如果不设置fetch=FetchType.LAZY,则默认是eager,不仅会加载id,firstname,lastname等属性,而且会加载owner里面的属性。 JoinColumn指的是Phone(多)表对应Employee(一)表关联字段的名称。

OneToMany设置

设置OneToMany的具体方法如下:
@Entity
public class Employee {
  @Id
  @Column(name="EMP_ID")
  private long id;
  ...
  @OneToMany(mappedBy="owner")
  private List<Phone> phones;
  ...
}
具体说明:
mappedBy="owner" 指的是在Phone这个实体类里面对应的Employee用的是哪个属性。OneToMany必须写mappedBy,不然会多生成一张没用的中间表,因为如果没写mappedBy,JPA不知道具体怎样做关联。

本文参考:https://en.wikibooks.org/wiki/Java_Persistence/OneToMany http://stackoverflow.com/questions/11938253/jpa-joincolumn-vs-mappedby 欢迎关注橙子博客微信公众号:chengziboke888

查看原文:http://zccbbg.top/2016/11/29/jpa%e4%b8%ad%e7%9a%84manytoone%e5%92%8conetomany/
我能理解你的问题,您想知道如何在JPA 2.2.10 SQL查询使用Dto @OneToMany。在JPA,@OneToMany关系表示一个实体具有多个子实体。Dto(Data Transfer Object)用于在不同层之间传输数据。要在SQL查询使用Dto @OneToMany,请遵循以下步骤: 1. 创建Dto类和其对应的子Dto类。 2. 在Dto类使用@OneToMany注释来指定实体类和关联属性。 3. 在SQL查询使用JOIN语句来连接Dto和相关的实体类。 4. 通过使用GROUP BY子句和构造函数表达式将结果转换为Dto对象。 下面是一个示例: ``` @Entity public class ParentEntity { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String name; @OneToMany(mappedBy = "parent", fetch = FetchType.LAZY) private List<ChildEntity> children; // getters and setters } @Entity public class ChildEntity { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String name; @ManyToOne(fetch = FetchType.LAZY) private ParentEntity parent; // getters and setters } public class ParentDto { private Long id; private String name; private List<ChildDto> children; public ParentDto(Long id, String name, List<ChildDto> children) { this.id = id; this.name = name; this.children = children; } // getters and setters } public class ChildDto { private Long id; private String name; public ChildDto(Long id, String name) { this.id = id; this.name = name; } // getters and setters } String sql = "SELECT p.id, p.name, c.id, c.name FROM ParentEntity p JOIN p.children c"; List<Object[]> resultList = entityManager.createQuery(sql).getResultList(); Map<Long, ParentDto> parentMap = new HashMap<>(); for (Object[] result : resultList) { Long parentId = (Long) result[0]; String parentName = (String) result[1]; Long childId = (Long) result[2]; String childName = (String) result[3]; ParentDto parent = parentMap.get(parentId); if (parent == null) { parent = new ParentDto(parentId, parentName, new ArrayList<>()); parentMap.put(parentId, parent); } parent.getChildren().add(new ChildDto(childId, childName)); } List<ParentDto> parentDtos = new ArrayList<>(parentMap.values()); ``` 希望这能回答您的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员诚哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值