41 lines
1.1 KiB
Perl
41 lines
1.1 KiB
Perl
package Pear::LocalLoop::Schema::Result::ViewQuantisedTransactionPg;
|
|
|
|
use strict;
|
|
use warnings;
|
|
|
|
use base 'DBIx::Class::Core';
|
|
|
|
__PACKAGE__->table_class('DBIx::Class::ResultSource::View');
|
|
__PACKAGE__->table('view_quantised_transactions');
|
|
__PACKAGE__->result_source_instance->is_virtual(1);
|
|
|
|
__PACKAGE__->result_source_instance->view_definition(
|
|
qq/
|
|
SELECT "value",
|
|
"distance",
|
|
"purchase_time",
|
|
"buyer_id",
|
|
"seller_id",
|
|
DATE_TRUNC('hour', "purchase_time") AS "quantised_hours",
|
|
DATE_TRUNC('day', "purchase_time") AS "quantised_days",
|
|
DATE_TRUNC('week', "purchase_time") AS "quantised_weeks",
|
|
DATE_TRUNC('month', "purchase_time") AS "quantised_months"
|
|
FROM "transactions"
|
|
/
|
|
);
|
|
|
|
__PACKAGE__->belongs_to(
|
|
"buyer",
|
|
"Pear::LocalLoop::Schema::Result::Entity",
|
|
{ id => "buyer_id" },
|
|
{ is_deferrable => 0, on_delete => "NO ACTION", on_update => "NO ACTION" },
|
|
);
|
|
|
|
__PACKAGE__->belongs_to(
|
|
"seller",
|
|
"Pear::LocalLoop::Schema::Result::Entity",
|
|
{ id => "seller_id" },
|
|
{ is_deferrable => 0, on_delete => "NO ACTION", on_update => "NO ACTION" },
|
|
);
|
|
|
|
1;
|