首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用recursive_update

如何使用recursive_update
EN

Stack Overflow用户
提问于 2022-10-16 19:24:27
回答 1查看 36关注 0票数 2

我刚刚开始使用DBx::Class,并开始稍微理解,但它很复杂。

我想叫"recursive_update“,但我无法管理如何使用它。

如果我正确理解文档,我必须将它包含在DBIx::Class::Schema::Loader创建的./My/Schema.pm中。

代码语言:javascript
复制
__PACKAGE__->load_namespaces(default_resultset_class => '+DBIx::Class::ResultSet::RecursiveUpdate');

当我想更新数据时,我使用ResultSet和关系。

代码语言:javascript
复制
my $result = $schema->resultset('Table')->find($id});
$result->recursive_update({
            'rel_table' => [....),
});

不幸的是,我遇到了一个错误:

代码语言:javascript
复制
Can't locate object method "recursive_update" via package My::Schema::Result::Table"

我的错在哪里?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-10-17 05:58:14

必须在recursive_update对象上调用ResultSet对象,而不是结果对象。

您可能想要向结果基类中添加一个助手方法(如果您已经有一个其他的创建方法,因为它对许多事情都有意义),它会将ResultSet限制在被调用的结果对象上,并在其上调用recursive_update

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

https://stackoverflow.com/questions/74090103

复制
相关文章

相似问题

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