1 package DBIx::Class::Storage::DBI::MSSQL;
6 use base qw/DBIx::Class::Storage::DBI::AmbiguousGlob DBIx::Class::Storage::DBI/;
8 __PACKAGE__->sql_maker_class('DBIx::Class::SQLAHacks::MSSQL');
10 sub _dbh_last_insert_id {
11 my ($self, $dbh, $source, $col) = @_;
12 my ($id) = $dbh->selectrow_array('SELECT SCOPE_IDENTITY()');
16 sub build_datetime_parser {
18 my $type = "DateTime::Format::Strptime";
20 $self->throw_exception("Couldn't load ${type}: $@") if $@;
21 return $type->new( pattern => '%Y-%m-%d %H:%M:%S' ); # %F %T
24 sub sqlt_type { 'SQLServer' }
27 my ( $self, $opts ) = @_;
30 $self->{_sql_maker_opts} = { %$opts };
33 return { limit_dialect => 'Top', %{$self->{_sql_maker_opts}||{}} };
40 DBIx::Class::Storage::DBI::MSSQL - Storage::DBI subclass for MSSQL
44 This subclass supports MSSQL, and can in theory be used directly
45 via the C<storage_type> mechanism:
47 $schema->storage_type('::DBI::MSSQL');
48 $schema->connect_info('dbi:....', ...);
50 However, as there is no L<DBD::MSSQL>, you will probably want to use
51 one of the other DBD-specific MSSQL classes, such as
52 L<DBIx::Class::Storage::DBI::Sybase::MSSQL>. These classes will
53 merge this class with a DBD-specific class to obtain fully
54 correct behavior for your scenario.
62 =head2 build_datetime_parser
64 The resulting parser handles the MSSQL C<DATETIME> type, but is almost
65 certainly not sufficient for the other MSSQL 2008 date/time types.
69 Brian Cassidy <bricas@cpan.org>
73 You may distribute this code under the same terms as Perl itself.