X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FStorage%2FDBI%2FODBC%2FMicrosoft_SQL_Server.pm;h=74fed68f36d42b7a34454ea52c4eee7dbad2ab76;hb=ed7ab0f4ce1a9118ea6285ee562ef003085a6b64;hp=1b0c5d819ff5c8cd44a7d0d5f0a53df9ff4107c8;hpb=ae5a51b5a21c9c7f3e3ddf50f653965fadf54e74;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/Storage/DBI/ODBC/Microsoft_SQL_Server.pm b/lib/DBIx/Class/Storage/DBI/ODBC/Microsoft_SQL_Server.pm index 1b0c5d8..74fed68 100644 --- a/lib/DBIx/Class/Storage/DBI/ODBC/Microsoft_SQL_Server.pm +++ b/lib/DBIx/Class/Storage/DBI/ODBC/Microsoft_SQL_Server.pm @@ -2,95 +2,188 @@ package DBIx::Class::Storage::DBI::ODBC::Microsoft_SQL_Server; use strict; use warnings; -use base qw/DBIx::Class::Storage::DBI/; +use base qw/DBIx::Class::Storage::DBI::MSSQL/; +use mro 'c3'; -sub _prep_for_execute { - my $self = shift; - my ($op, $extra_bind, $ident, $args) = @_; +use List::Util(); +use Scalar::Util (); +use Try::Tiny; - my ($sql, $bind) = $self->SUPER::_prep_for_execute(@_); - $sql .= ';SELECT SCOPE_IDENTITY()' if $op eq 'insert'; +__PACKAGE__->mk_group_accessors(simple => qw/ + _using_dynamic_cursors +/); - return ($sql, $bind); -} +=head1 NAME -sub insert { - my ($self, $source, $to_insert) = @_; +DBIx::Class::Storage::DBI::ODBC::Microsoft_SQL_Server - Support specific +to Microsoft SQL Server over ODBC - my $bind_attributes = $self->source_bind_attributes($source); - my (undef, $sth) = $self->_execute( 'insert' => [], $source, $bind_attributes, $to_insert); - $self->{_scope_identity} = $sth->fetchrow_array; +=head1 DESCRIPTION - return $to_insert; -} +This class implements support specific to Microsoft SQL Server over ODBC. It is +loaded automatically by by DBIx::Class::Storage::DBI::ODBC when it detects a +MSSQL back-end. + +Most of the functionality is provided from the superclass +L. + +=head1 MULTIPLE ACTIVE STATEMENTS + +The following options are alternative ways to enable concurrent executing +statement support. Each has its own advantages and drawbacks. + +=head2 connect_call_use_dynamic_cursors + +Use as: -sub last_insert_id { shift->{_scope_identity} } + on_connect_call => 'use_dynamic_cursors' -sub sqlt_type { 'SQLServer' } +in your L as one way to enable multiple +concurrent statements. -sub _sql_maker_opts { - my ( $self, $opts ) = @_; +Will add C<< odbc_cursortype => 2 >> to your DBI connection attributes. See +L for more information. - if ( $opts ) { - $self->{_sql_maker_opts} = { %$opts }; - } +Alternatively, you can add it yourself and dynamic cursor support will be +automatically enabled. - return { limit_dialect => 'Top', %{$self->{_sql_maker_opts}||{}} }; +If you're using FreeTDS, C must be set to at least C<8.0>. + +This will not work with CODE ref connect_info's. + +B this will break C, and C