4

我正在使用 Catalyst 框架中的 DBIx::Class。我的本地目标是在用户和任务之间添加新的多对多关系。但我需要一个小技巧。用户在任务中可以有不同的角色(如“工人”或“旁观者”)。

所以我有这些字段的用户表:

  • ID
  • 姓名

我有这些字段的任务表:

  • ID
  • 标题
  • 描述

我有这些字段的关系表user_tasks :

  • 用户身份
  • task_id
  • 角色

我已经设置了从用户到用户任务的has_many,从任务到用户任务的has_many以及用户任务之间对应的many_to_many关系。那个简单的部分可以正常工作。

然后,例如,我想获取我的用户列表,包括用户在 $task_id 标识的任务中的角色:

my $users = $schema->resultset('User')->with_task_role($task_id);
while (my $u = $users->next) {
    print "User: " . $u->name . ", role: " . $u->get_column('task_role');
}

那么我应该如何对这个with_task_role自定义结果集进行编码,以在我的查询中使用用户的任务角色来获取这个附加字段?

4

2 回答 2

4

首先,多对多不是关系。它是一个访问器(一个关系桥梁)。

其次,DBIx::Class 有一个优秀的文档。看看加入/预取。在您的 ResultSet/User.pm 文件中,您应该有类似的内容:

sub with_task_role {
    my ($self, $task_id) = @_;

    return $self->search({
            'task.task_id' => $task_id,
        },
        {
            join     => { 'user_task' => 'task' },
            prefetch => { 'user_task' => 'task' },
        },
    );
}

PS:对不起,我没有看到Ashley已经回答了PS2:在最后一行之前“})”应该只是“)”(已修复)

于 2011-05-24T15:50:30.780 回答
2

这是DBIC 主类(.xul 资源)User的 XUL(任何浏览器不再支持)幻灯片中未更改的一些结果集代码。我强烈建议下载幻灯片,以纯文本形式阅读。它们让我大开眼界。

您必须调整结果源名称以匹配您自己的名称,但这应该是您想要的,并且使用它可以更灵活地启动, _role_to_id它允许您传递角色对象或 id。

  sub with_role {
    my ($self, $role) = @_;
    $self->search({
        'role_links.role_id' => $role->id
      },
      { join => 'role_links' }
    );
  }

  sub _role_to_id {
    my ($self, $role) = @_;
    return blessed($role) ? $role->id : $role;
  }

  sub with_any_role {
    my ($self, @roles) = @_;
    $self->search({
        'role_links.role_id' => {
          -in => [
            map { $self->_role_to_id($_) } @roles
          ]
        }
      },
      { join => 'role_links' }
    );
  }
于 2011-05-24T15:34:26.937 回答