⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rangetable.pm

📁 普通的ETL工具
💻 PM
字号:
# vim:ts=4 sw=4
# ----------------------------------------------------------------------------------------------------
#  Name		: ETL::Pequel3::Type::Section::RangeTable.pm
#  Created	: 22 June 2006
#  Author	: Mario Gaffiero (gaffie)
#
# Copyright 1999-2007 Mario Gaffiero.
# 
# This file is part of Pequel(TM).
# 
# Pequel is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; version 2 of the License.
# 
# Pequel is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
# 
# You should have received a copy of the GNU General Public License
# along with Pequel; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
# ----------------------------------------------------------------------------------------------------
# Modification History
# When          Version     Who     What
# ----------------------------------------------------------------------------------------------------
package ETL::Pequel3::Type::Section::RangeTable;
require 5.005_62;
use strict;
use warnings;
use ETL::Pequel3::Type::Section;
# ----------------------------------------------------------------------------------------------------
{
	package ETL::Pequel3::Type::Section::RangeTable;
	use base qw(ETL::Pequel3::Type::Section::Abstract);
	use Class::STL::ClassMembers
		qw( 
			table_name
			table_ref
		),
		Class::STL::ClassMembers::DataMember->new(name => 'target_mem_name', default => 'table_name'),
		Class::STL::ClassMembers::DataMember->new(name => 'section_name', default => 'range_table'),
		Class::STL::ClassMembers::DataMember->new(name => 'item_type', default => __PACKAGE__ . '::Item'),
		Class::STL::ClassMembers::DataMember->new(name => 'element_type', default => "@{[ __PACKAGE__ ]}");
	use Class::STL::ClassMembers::SingletonConstructor;
	sub new_extra
	{
		my $self = shift;
		$self->attributes()->push_back(
			$self->attributes()->factory(name => 'table_name', required => 1),
			$self->attributes()->factory(name => 'type', required => 1, validate => '^(local|external|dbi|pequel)$'),
			ETL::Pequel3::Type::Properties::DataSetSpec->new(required => 1),
			$self->attributes()->factory(name => 'static'),
			$self->attributes()->factory(name => 'lower_key_field', required => 1),
			$self->attributes()->factory(name => 'upper_key_field', required => 1),
			$self->attributes()->factory(name => 'key_type'),
			$self->attributes()->factory(name => 'field_map'), # =fname:col,fname:col,...
		);
	}
	sub prepare
	{
		my $self = shift;
		$self->table_ref($self->pequel_ref()->user_tables()->factory(
			name => $self->table_name(),
			type => $self->attributes()->type(),
			static => $self->attributes()->static(),
			dataset_spec => $self->attributes()->dataset_spec(),
			key_field => $self->attributes()->key_field(),
			key_type => $self->attributes()->key_type(),
			field_map => $self->attributes()->field_map(),
			pequel_ref => $self->pequel_ref(),
		));
		$self->table_ref()->prepare($self->pequel_ref(), $self->items());
	}
	sub select
	{
		my $self = shift;
		my %p = @_;
		$self->err()->user_error(10211, "Section '@{[ 
			$self->section_name() ]}' select() function requires '@{[ $self->target_mem_name() ]}' parameter!")
			unless (exists($p{$self->target_mem_name()}));
		my $s;
		return $s if (($s = $self->exists($p{$self->target_mem_name()})) != 0);
		$self->add(%p);
		$self->back()->attributes()->set(@_);
		return $self->back();
	}

	package ETL::Pequel3::Type::Section::RangeTable::Item;
	use base qw(ETL::Pequel3::Type::Section::Item::Abstract);
	use Class::STL::ClassMembers;
	use Class::STL::ClassMembers::Constructor;
	sub new_extra
	{
		my $self = shift;
		$self->attributes()->push_back(
			$self->attributes()->factory(name => 'lower_key_value'), # don't need -- just repeat data_values for all keys within lower - upper
			$self->attributes()->factory(name => 'upper_key_value'),
			$self->attributes()->factory(name => 'data_values'),
		);
	}
}
# ----------------------------------------------------------------------------------------------------
1;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -