2

我正在使用Catalyst::Plugin::AutoCRUD并使用链接的 CPAN 页面中提供的说明生成 DBIx 模式。具体来说,我复制/粘贴了那里列出的命令,并仅更改了与我的数据库相关的详细信息('pg' => 'mysql'、不同的用户名/密码等)。

我现在有一个模式 DBIC::Database::foo::Schema。Schema 既是一个包含我数据库中每个表的 *.pm 的文件,也是它自己的 Schema.pm。

我的配置文件包含以下条目:

<Model::AutoCRUD::DBIC>
  schema_class   Database::foo::Schema
  connect_info   dbi:mysql:dbname=foo
  connect_info   user
  connect_info   pass
  <connect_info>
      AutoCommit      1
  </connect_info>
</Model::AutoCRUD::DBIC>

当我启动 AutoCRUD 服务器时,我收到以下错误消息:

Couldn't instantiate component "DemoApp::Model::AutoCRUD::DBIC", "Attribute (schema_class)
does not pass the type constraint because: Validation failed for
'Catalyst::Model::DBIC::Schema::Types::SchemaClass' with value Database::foo::Schema at
/Library/Perl/5.12/darwin-thread-multi-2level/Moose/Meta/Attribute.pm line 1275.

由于我是 Catalyst 和这个插件的新手,我不知道如何解决这个问题。谷歌并不是很有帮助——我发现了这个讨论,但据我所知,问题是 Catalyst 被指向了错误的 *.pm(尽管我可能误读了这个)。

如果这有帮助,这里是 Schema.pm 的内容:

use utf8;
package DBIC::Database::foo::Schema;

# Created by DBIx::Class::Schema::Loader
# DO NOT MODIFY THE FIRST PART OF THIS FILE

use strict;
use warnings;

use base 'DBIx::Class::Schema';

__PACKAGE__->load_namespaces;


# Created by DBIx::Class::Schema::Loader v0.07024 @ 2012-05-20 07:25:21
# DO NOT MODIFY THIS OR ANYTHING ABOVE! md5sum:cevz/k4rUWIcEhMl29r0QA


# You can replace this text with custom code or comments, and it will be preserved on  regeneration
1;

请帮忙!

4

2 回答 2

2

您的架构已命名DBIC::Database::Foo::Schema,但在您拥有的配置文件中Database::foo::Schema。这些名称区分大小写,因此要么更改架构路径和文件的名称,要么更正配置。

于 2012-05-20T15:23:02.390 回答
0

从Catalyst 手册中完全重建 DBIC 类解决了这个问题。虽然我无法确定 Moose 在第一组类中不可接受的内容,但第二组类还有一个问题:__PACKAGE__->meta->make_immutable;为每个类(即在每个 *.pm 中)都生成了该行。将其注释掉并重新启动 Catalyst 会产生一个正常运行的 CRUD 应用程序。

于 2012-05-21T11:54:25.427 回答