[Bast-commits] r7726 - in
DBIx-Class/0.08/branches/sybase_bulkinsert_support:
lib/DBIx/Class/Storage/DBI lib/DBIx/Class/Storage/DBI/Sybase t
caelum at dev.catalyst.perl.org
caelum at dev.catalyst.perl.org
Thu Sep 24 09:21:19 GMT 2009
Author: caelum
Date: 2009-09-24 09:21:18 +0000 (Thu, 24 Sep 2009)
New Revision: 7726
Modified:
DBIx-Class/0.08/branches/sybase_bulkinsert_support/lib/DBIx/Class/Storage/DBI/Sybase.pm
DBIx-Class/0.08/branches/sybase_bulkinsert_support/lib/DBIx/Class/Storage/DBI/Sybase/NoBindVars.pm
DBIx-Class/0.08/branches/sybase_bulkinsert_support/t/746sybase.t
Log:
minor cleanups, test update of blob to NULL
Modified: DBIx-Class/0.08/branches/sybase_bulkinsert_support/lib/DBIx/Class/Storage/DBI/Sybase/NoBindVars.pm
===================================================================
--- DBIx-Class/0.08/branches/sybase_bulkinsert_support/lib/DBIx/Class/Storage/DBI/Sybase/NoBindVars.pm 2009-09-24 06:47:39 UTC (rev 7725)
+++ DBIx-Class/0.08/branches/sybase_bulkinsert_support/lib/DBIx/Class/Storage/DBI/Sybase/NoBindVars.pm 2009-09-24 09:21:18 UTC (rev 7726)
@@ -59,9 +59,6 @@
return $value;
}
-# for tests
-sub _can_insert_bulk { 0 }
-
1;
=head1 NAME
Modified: DBIx-Class/0.08/branches/sybase_bulkinsert_support/lib/DBIx/Class/Storage/DBI/Sybase.pm
===================================================================
--- DBIx-Class/0.08/branches/sybase_bulkinsert_support/lib/DBIx/Class/Storage/DBI/Sybase.pm 2009-09-24 06:47:39 UTC (rev 7725)
+++ DBIx-Class/0.08/branches/sybase_bulkinsert_support/lib/DBIx/Class/Storage/DBI/Sybase.pm 2009-09-24 09:21:18 UTC (rev 7726)
@@ -428,13 +428,8 @@
if $is_identity_update;
}
-# check that we're not updating a blob column that's also in $where
- for my $blob (grep $self->_is_lob_column($source, $_), $source->columns) {
- if (exists $where->{$blob} && exists $fields->{$blob}) {
- croak
-'Update of TEXT/IMAGE column that is also in search condition impossible';
- }
- }
+# If there are any blobs in $where, Sybase will return a descriptive error
+# message.
# update+blob update(s) done atomically on separate connection
$self = $self->_writer_storage;
@@ -475,6 +470,7 @@
return $wantarray ? @res : $res[0];
}
+# for IDENTITY_INSERT / IDENTITY_UPDATE
sub _set_session_identity {
my ($self, $op, $table, $off_on) = @_;
@@ -505,9 +501,6 @@
}
}
-# for tests
-sub _can_insert_bulk { 1 }
-
sub insert_bulk {
my $self = shift;
my ($source, $cols, $data) = @_;
@@ -540,14 +533,8 @@
if (not $use_bulk_api) {
my $blob_cols = $self->_remove_blob_cols_array($source, $cols, $data);
- my $dumb_last_insert_id =
- $identity_col
- && (not $is_identity_insert)
- && ($self->_identity_method||'') ne '@@IDENTITY';
-
($self, my ($guard)) = do {
- if ($self->{transaction_depth} == 0 &&
- ($blob_cols || $dumb_last_insert_id)) {
+ if ($self->{transaction_depth} == 0 && $blob_cols) {
($self->_writer_storage, $self->_writer_storage->txn_scope_guard);
}
else {
@@ -1053,10 +1040,10 @@
=head1 TRANSACTIONS
Due to limitations of the TDS protocol, L<DBD::Sybase>, or both; you cannot
-begin a transaction while there are active cursors. An active cursor is, for
-example, a L<ResultSet|DBIx::Class::ResultSet> that has been executed using
-C<next> or C<first> but has not been exhausted or
-L<reset|DBIx::Class::ResultSet/reset>.
+begin a transaction while there are active cursors; nor can you use multiple
+active cursors within a transaction. An active cursor is, for example, a
+L<ResultSet|DBIx::Class::ResultSet> that has been executed using C<next> or
+C<first> but has not been exhausted or L<reset|DBIx::Class::ResultSet/reset>.
For example, this will not work:
@@ -1070,6 +1057,11 @@
}
});
+This won't either:
+
+ my $first_row = $large_rs->first;
+ $schema->txn_do(sub { ... });
+
Transactions done for inserts in C<AutoCommit> mode when placeholders are in use
are not affected, as they are done on an extra database handle.
Modified: DBIx-Class/0.08/branches/sybase_bulkinsert_support/t/746sybase.t
===================================================================
--- DBIx-Class/0.08/branches/sybase_bulkinsert_support/t/746sybase.t 2009-09-24 06:47:39 UTC (rev 7725)
+++ DBIx-Class/0.08/branches/sybase_bulkinsert_support/t/746sybase.t 2009-09-24 09:21:18 UTC (rev 7726)
@@ -211,7 +211,7 @@
# test insert_bulk using populate.
SKIP: {
skip 'insert_bulk not supported', 4
- unless $schema->storage->_can_insert_bulk;
+ unless $storage_type !~ /NoBindVars/i;
lives_ok {
$schema->resultset('Artist')->populate([
@@ -247,7 +247,7 @@
# make sure insert_bulk works a second time on the same connection
SKIP: {
skip 'insert_bulk not supported', 3
- unless $schema->storage->_can_insert_bulk;
+ unless $storage_type !~ /NoBindVars/i;
lives_ok {
$schema->resultset('Artist')->populate([
@@ -294,7 +294,7 @@
# now test insert_bulk with IDENTITY_INSERT
SKIP: {
skip 'insert_bulk not supported', 3
- unless $schema->storage->_can_insert_bulk;
+ unless $storage_type !~ /NoBindVars/i;
lives_ok {
$schema->resultset('Artist')->populate([
@@ -457,12 +457,12 @@
is((grep $_->clob eq $new_str, $rs->all), 2,
'TEXT column set correctly via insert_bulk');
- # make sure impossible blob update throws
- throws_ok {
- $rs->update({ clob => 'foo' });
- $rs->create({ clob => 'bar' });
- $rs->search({ clob => 'foo' })->update({ clob => 'bar' });
- } qr/impossible/, 'impossible blob update throws';
+ lives_and {
+ $rs->delete;
+ $rs->create({ blob => $binstr{large} }) for (1..2);
+ $rs->update({ blob => undef });
+ is((grep !defined($_->blob), $rs->all), 2);
+ } 'blob update to NULL';
}
# test MONEY column support
More information about the Bast-commits
mailing list