gpt4 book ai didi

perl - DBIx :Class many-to-many relationship with additional attribute

转载 作者:行者123 更新时间:2023-12-05 00:38:07 25 4
gpt4 key购买 nike

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

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

  • id
  • 姓名

  • 我有 任务包含这些字段的表:
  • id
  • 标题
  • 说明

  • 我有关系表 用户任务使用这些字段:
  • 用户 ID
  • 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 自定义结果集以在我的查询中使用用户的任务角色获取此附加字段?

    最佳答案

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

    其次,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:在最后一行“})”之前应该只有“)”(已修复)

    关于perl - DBIx :Class many-to-many relationship with additional attribute,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6112471/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com