首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Play Framework1.2.x中的ManyToMany测试夹具

Play Framework1.2.x中的ManyToMany测试夹具
EN

Stack Overflow用户
提问于 2012-03-15 06:34:29
回答 1查看 854关注 0票数 4

我用的是Play!1.2.4 + Morhpia / MongoDB。

我的模特是美容院和造型师,他们有很多的关系。但是,我无法正确地定义测试数据来表示这种关系。

以下是我所做的

代码语言:javascript
复制
Salon(salon1):
  name: salon1
  city: singapore
  country: singapore

Stylist(stylist1):
  firstName: stylist1
  lastName: stylist1
  title: Stylist 1
  price: $100
  salons: [salon1]

使用这些数据,发型师包含对沙龙的引用,但反之亦然。

如何实现双向参考?

谢谢你,Sri

下面是模型类。

代码语言:javascript
复制
@Entity("salons")
public class Salon extends Model {
  // ...
  @Reference
  @ManyToMany
  public List<Stylist> stylists;
  // ...
}

@Entity("stylists")
public class Stylist extends Model {
  // ..
  @Reference
  @ManyToMany
  public List<Salon> salons;
  // ..
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-03-15 06:44:02

你说双向参照是什么意思?

如果您的意思是您希望能够在代码中访问您的沙龙实体中的发型师,那么您将需要这样的内容:

代码语言:javascript
复制
public class Salon extends Model {

    @ManyToMany
    @JoinTable(name = "salon_stylist", ...)
    public List<Stylist> stylists;

    ...
}

您的Stylist实体可以如下所示:

代码语言:javascript
复制
public class Stylist extends Model {

    @ManyToMany
    @JoinTable(name = "salon_stylist", ...)
    public List<Salon> salons;

    ...
}        

那么你的yml看起来就像这样:

代码语言:javascript
复制
Salon(salon1):
  name: salon1
  city: singapore
  country: singapore

Salon(salon2):
  name: salon2
  city: tokyo
  country: japan

Stylist(stylist1):
  firstName: stylist1
  lastName: stylist1
  title: Stylist 1
  price: $100
  salons: 
    - salon1
    - salon2

仅仅说stylist1属于salon1,而salon2在yml中就足够了(也就是说,您不应该在两个沙龙yml条目中声明相同的内容)。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9715000

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档