Почему я получаю неинициализированное значение в sprintf из объекта DBIx :: Class :: InflateColumn :: DateTime? - PullRequest
2 голосов
/ 01 ноября 2010

Похоже, это больше всего началось, так как я обновляю свой DBIx :: Class, и я не могу понять, что я делаю неправильно.

Use of uninitialized value in sprintf at /opt/perl-5.10.1/lib/site_perl/5.10.1/DBIx/Class/InflateColumn/DateTime.pm line 192.
 at /opt/perl-5.10.1/lib/site_perl/5.10.1/DBIx/Class/InflateColumn/DateTime.pm line 192
    DBIx::Class::InflateColumn::DateTime::_flate_or_fallback('OpusVL::AppKitX::TelecomsBilling::Schema::Result::AsteriskCdr...', '2009-11-13 09:00:00', 'HASH(0x2a85488)', 'parse_%s') called at /opt/perl-5.10.1/lib/site_perl/5.10.1/DBIx/Class/InflateColumn/DateTime.pm line 199

Мое определение столбца в файле результатов:

package Module1::Schema::Result::AsteriskCdrRecord;

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

use strict;
use warnings;

use Moose;
use MooseX::NonMoose;
use namespace::autoclean;
extends 'DBIx::Class::Core';

__PACKAGE__->load_components("InflateColumn::DateTime");

__PACKAGE__->table("asterisk_cdr_records");

__PACKAGE__->add_columns(
  "record_id",
  {
    data_type         => "integer",
    is_auto_increment => 1,
    is_nullable       => 0,
    sequence          => "asterisk_cdr_records_record_id_seq",
  },
  "import_id",
  { data_type => "integer", is_foreign_key => 1, is_nullable => 0 },
  "line",
  { data_type => "integer", is_nullable => 0 },
  "account_ref",
  { data_type => "varchar", is_foreign_key => 1, is_nullable => 0, size => 20 },
  "b_number",
  { data_type => "varchar", is_nullable => 0, size => 80 },
  "call_start",
  { data_type => "timestamp", is_nullable => 0 },
  "call_end",
  { data_type => "timestamp", is_nullable => 0 },
  "created",
  {
    data_type     => "timestamp",
    default_value => \"current_timestamp",
    is_nullable   => 0,
    original      => { default_value => \"now()" },
  },
  "updated",
  {
    data_type     => "timestamp",
    default_value => \"current_timestamp",
    is_nullable   => 0,
    original      => { default_value => \"now()" },
  },
);
__PACKAGE__->set_primary_key("record_id");
__PACKAGE__->add_unique_constraint(
  "idx_astcdr_records_uni",
  ["account_ref", "b_number", "call_start", "call_end"],
);

__PACKAGE__->belongs_to(
  "import_id",
  "Module1::Schema::Result::AsteriskCdrImport",
  { import_id => "import_id" },
  { is_deferrable => 1, on_delete => "CASCADE", on_update => "CASCADE" },
);

# Created by DBIx::Class::Schema::Loader v0.07002 @ 2010-10-15 10:08:29
# DO NOT MODIFY THIS OR ANYTHING ABOVE! md5sum:mKgpEpbGV/m/CgsjvKLzZA

__PACKAGE__->load_components(qw/TimeStamp Core/);
# Adjust some column data that was automatically output by the _create.pl script.
__PACKAGE__->add_columns
(
    # Force these to inflate via DataTime.
    "call_start",
    {
        inflate_datetime    => 1 ,
        data_type           => "timestamp without time zone",
        default_value       => undef,
        is_nullable         => 0,
        size                => 8,
    },
    "call_end",
    {
        inflate_datetime    => 1,
        data_type           => "timestamp without time zone",
        default_value       => undef,
        is_nullable         => 0,
        size                => 8,
    },
    # Add automatic date handling
    "created",
    { data_type => 'datetime', set_on_create => 1 },
    "updated",
    { data_type => 'datetime', set_on_create => 1, set_on_update => 1 },
);

Возмущение, связанное с повторными действиями после перерыва, связано с тем, чтобы у Schema :: Loader не возникало проблем с изменением сгенерированного кода.

Что нужно сделать, чтобы предотвратитьпредупреждения о неинициализированном значении?Это использует версию 0.08124 DBIx :: Class (хотя я думаю, что это произошло и с версией раньше, но я не удосужился исследовать эту проблему).

1 Ответ

5 голосов
/ 01 ноября 2010

Несколько вещей для улучшения кода выше:

  • Удалите лишнее "Ядро" из второго вызова load_components, оно уже есть в строке "extends".

  • Второй вызов «add_columns» может быть сокращен с помощью нового синтаксиса «+ col», который позволяет вам изменять / обновлять существующее определение столбца, а не добавлять полностью новое, см. ResultSource документы .

...