X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FSchema%2FLoader%2FDBI%2FOracle.pm;h=19be9aa507bed75901da2c8216b910ac6a18d2b5;hb=1fa1884903b09903ce89a3814e41bac9e91eea9d;hp=de4e4a12f849b606965f700ecbae0ef600acee69;hpb=e344eed6c9cf62f2e5e78a31d8c499014a16c68c;p=dbsrgits%2FDBIx-Class-Schema-Loader.git diff --git a/lib/DBIx/Class/Schema/Loader/DBI/Oracle.pm b/lib/DBIx/Class/Schema/Loader/DBI/Oracle.pm index de4e4a1..19be9aa 100644 --- a/lib/DBIx/Class/Schema/Loader/DBI/Oracle.pm +++ b/lib/DBIx/Class/Schema/Loader/DBI/Oracle.pm @@ -6,7 +6,7 @@ use base 'DBIx::Class::Schema::Loader::DBI'; use Carp::Clan qw/^DBIx::Class/; use Class::C3; -our $VERSION = '0.04999_02'; +our $VERSION = '0.04999_13'; =head1 NAME @@ -36,7 +36,14 @@ sub _setup { $self->next::method(@_); my $dbh = $self->schema->storage->dbh; - $self->{db_schema} ||= $dbh->selectrow_array('SELECT USER FROM DUAL', {}); + + my ($current_schema) = $dbh->selectrow_array('SELECT USER FROM DUAL', {}); + + $self->{db_schema} ||= $current_schema; + + if (lc($self->db_schema) ne lc($current_schema)) { + $dbh->do('ALTER SESSION SET current_schema=' . $self->db_schema); + } } @@ -78,14 +85,14 @@ sub _table_uniq_info { my $sth = $dbh->prepare_cached( q{ - SELECT constraint_name, ucc.column_name - FROM user_constraints JOIN user_cons_columns ucc USING (constraint_name) - WHERE ucc.table_name=? AND constraint_type='U' - ORDER BY ucc.position + SELECT constraint_name, acc.column_name + FROM all_constraints JOIN all_cons_columns acc USING (constraint_name) + WHERE acc.table_name=? and acc.owner = ? AND constraint_type='U' + ORDER BY acc.position }, {}, 1); - $sth->execute(uc $table); + $sth->execute(uc $table,$self->{db_schema} ); my %constr_names; while(my $constr = $sth->fetchrow_arrayref) { my $constr_name = lc $constr->[0]; @@ -131,8 +138,8 @@ sub _extra_column_info { my $sth = $dbh->prepare_cached( q{ SELECT COUNT(*) - FROM user_triggers ut JOIN user_trigger_cols utc USING (trigger_name) - WHERE utc.table_name = ? AND utc.column_name = ? + FROM all_triggers ut JOIN all_trigger_cols atc USING (trigger_name) + WHERE atc.table_name = ? AND atc.column_name = ? AND column_usage LIKE '%NEW%' AND column_usage LIKE '%OUT%' AND trigger_type = 'BEFORE EACH ROW' AND triggering_event LIKE '%INSERT%' }, @@ -153,9 +160,12 @@ L =head1 AUTHOR -TSUNODA Kazuya C +See L and L. + +=head1 LICENSE -Dagfinn Ilmari Mannsåker C +This library is free software; you can redistribute it and/or modify it under +the same terms as Perl itself. =cut