DBIx-BulkUtil
view release on metacpan or search on metacpan
lib/DBIx/BulkUtil.pm view on Meta::CPAN
$temp_dir = $opts{TempDir} || "." if $in_temp_dir;
require File::Temp;
my @temp_dir = $in_temp_dir ? (DIR => $temp_dir) : ();
my @unlink = $keep_temp ? (UNLINK => 0) : ();
my $error_file = File::Temp->new(
TEMPLATE => "${table}_XXXXX",
SUFFIX => ".err",
@temp_dir, @unlink,
);
chmod(0664, $error_file->filename());
$error_file->close();
my @packet_size = $opts{PacketSize} ? ( -A => $opts{PacketSize} ) : ();
my @passthru = $opts{PassThru} ? @{$opts{PassThru}} : ();
my ( $fmt_file, $tmp_fmt_file );
if ( $opts{FormatFile} ) {
$fmt_file = $opts{FormatFile};
} elsif ( ( $opts{ColumnList} && $opts{ColumnList} ) || ( $opts{Filler} && @{$opts{Filler}} ) ) {
($tmp_fmt_file,$fmt_file) = $self->mk_fmt_file(
lib/DBIx/BulkUtil.pm view on Meta::CPAN
$temp_dir = $opts{TempDir} || "." if $in_temp_dir;
my @temp_dir = $in_temp_dir ? (DIR => $temp_dir) : ();
my @unlink = ( $keep_temp || !defined(wantarray) ) ? (UNLINK => 0) : ();
$tmp_fmt_file = File::Temp->new(
TEMPLATE => "${table}_XXXXX",
SUFFIX => ".fmt",
@temp_dir, @unlink,
);
$fmt_file = $tmp_fmt_file->filename();
chmod(0664, $tmp_fmt_file);
$tmp_fmt_file->close();
}
my $delim = $opts{Delimiter} || "|";
my $row_delim = $opts{RowDelimiter} || "\n";
# Need escaped text in fmt file
# for CR/LF
for ($delim,$row_delim) {
s/\n/\\n/g;
lib/DBIx/BulkUtil.pm view on Meta::CPAN
my $temp_dir;
$temp_dir = $opts->{TempDir} || "." if $in_temp_dir;
my @temp_dir = $in_temp_dir ? (DIR => $temp_dir) : ();
my @unlink = $keep_temp ? (UNLINK => 0) : ();
my $ctl_fh = File::Temp->new(
TEMPLATE => "${table}_XXXXX",
SUFFIX => ".ctl",
@temp_dir, @unlink,
);
chmod(0664, $ctl_fh->filename());
my $bad_fh = File::Temp->new(
TEMPLATE => "${table}_XXXXX",
SUFFIX => ".bad",
@temp_dir, @unlink,
);
chmod(0664, $bad_fh->filename());
my $log_fh = File::Temp->new(
TEMPLATE => "${table}_XXXXX",
SUFFIX => ".log",
@temp_dir, @unlink,
);
chmod(0664, $log_fh->filename());
my $prm_fh = $stdin ? File::Temp->new(
TEMPLATE => "${table}_XXXXX",
SUFFIX => ".prm",
@temp_dir,
) : undef;
# NLS date format env variable does not work
# for sqlldr.
# So we must determine date fields and
# specify the format in the control file.
( run in 0.247 second using v1.01-cache-2.11-cpan-8d75d55dd25 )