perl – 如何使用Moose设置DBIx :: Class模式 – 明确指南
我发现很难找到有关如何使用Moose组装DBIx :: Class模式结构的信息.如何正确地(基本上工作)和现代Perl(良好的风格,快速,没有警告)?
这些是我的目标: >关注Moose’ >使用namespace :: autoclean和 >为Result和ResultSet使用公共基类 这些是我遇到的问题: >当使用__PACKAGE __-> meta-> make_immutable时,我收到警告,比如没有为MyApp :: Schema :: Result :: MyTable内联’new’,因为它没有继承默认的Moose :: Object :: new 解决方法
出现的问题的解决方案:
> make_immutable与非Moose新构造函数冲突:使用MooseX :: NonMoose自动处理;与其文件相比,不需要进一步的论据或选择;请注意,DBIx :: Class :: Schema没有新方法,因此MyApp :: Schema不需要这个帮助器 使用上面的解决方案,我的示例DBIx :: Class模式与Moose看起来像这样: 架构类: package MyApp::Schema; use Moose; # we want Moose use MooseX::MarkAsMethods autoclean => 1; # this helps removing unused symbols like Moose keywords # do NOT 'use MooseX::NonMoose' here because Schema class has no 'new' method extends 'DBIx::Class::Schema'; # the Moose way of inheritance # load all table modules automatically __PACKAGE__->load_namespaces( # ResultSet class for tables without custom ResultSet class # (would be DBIx::Class::ResultSet otherwise) default_resultset_class => '+MyApp::Schema::ResultSet',); # tell Moose this class is finished: some Moose stuff is removed and things go faster __PACKAGE__->meta->make_immutable; 1; 通用结果基类: # a base class for all table class of this app package MyApp::Schema::Result; use Moose; use MooseX::MarkAsMethods autoclean => 1; use MooseX::NonMoose; # this is important for correctly handling DBIx::Class' new extends 'DBIx::Class::Core'; # this is the right place to implement generic stuff # DBIx::Class::Cookbook recommends loading components in a central place __PACKAGE__->load_components(qw/ InflateColumn::DateTime ... /); __PACKAGE__->meta->make_immutable; 1; 通用ResultSet基类: package MyApp::Schema::ResultSet; use Moose; use MooseX::MarkAsMethods autoclean => 1; use MooseX::NonMoose; extends 'DBIx::Class::ResultSet'; __PACKAGE__->meta->make_immutable; 1; 表my_table的示例ResultSet类: package MyApp::Schema::ResultSet::MyTable; use Moose; use MooseX::MarkAsMethods autoclean => 1; extends 'MyApp::Schema::ResultSet'; sub oldest { my $self = shift; $self->search({},{order_by => {-ASC => 'date'}})->first; } __PACKAGE__->meta->make_immutable; 1; 表my_table的示例结果类: package MyApp::Schema::Result::MyTable; use Moose; use MooseX::MarkAsMethods autoclean => 1; extends 'MyApp::Schema::Result'; __PACKAGE__->table("my_table"); __PACKAGE__->add_columns( id => {data_type => "integer",is_auto_increment => 1},date => {data_type => "date"},); __PACKAGE__->set_primary_key("id"); __PACKAGE__->meta->make_immutable; 1; (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |