--- loncom/interface/lonmysql.pm 2003/03/13 19:08:52 1.9 +++ loncom/interface/lonmysql.pm 2003/03/21 16:04:42 1.12 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # MySQL utility functions # -# $Id: lonmysql.pm,v 1.9 2003/03/13 19:08:52 matthew Exp $ +# $Id: lonmysql.pm,v 1.12 2003/03/21 16:04:42 matthew Exp $ # # Copyright Michigan State University Board of Trustees # @@ -396,6 +396,26 @@ sub number_of_rows { return undef if (! defined(&update_table_info($table_id))); return $Tables{&translate_id($table_id)}->{'Rows'}; } +############################### + +=pod + +=item &get_dbh() + +Input: nothing + +Returns: the database handler, or undef on error. + +This routine allows the programmer to gain access to the database handler. +Be careful. + +=cut + +############################### +sub get_dbh { + return undef if (! defined(&connect_to_db())); + return $dbh; +} ############################### @@ -539,16 +559,16 @@ Input formats: }, ], 'PRIMARY KEY' => (index_col_name,...), - KEY => { name => 'idx_name', - columns => (col1,col2,..),}, - INDEX => { name => 'idx_name', - columns => (col1,col2,..),}, - UNIQUE => { index => 'yes', + KEY => [{ name => 'idx_name', + columns => (col1,col2,..),},], + INDEX => [{ name => 'idx_name', + columns => (col1,col2,..),},], + UNIQUE => [{ index => 'yes', name => 'idx_name', - columns => (col1,col2,..),}, - FULLTEXT => { index => 'yes', + columns => (col1,col2,..),},], + FULLTEXT => [{ index => 'yes', name => 'idx_name', - columns => (col1,col2,..),}, + columns => (col1,col2,..),},], } @@ -606,30 +626,35 @@ sub create_table { push (@Columns,'PRIMARY KEY ('.join(',',@{$table_des->{'PRIMARY KEY'}}) .')'); } - foreach ('KEY','INDEX') { - if (exists($table_des->{$_})) { - my $text = $_.' '; - if (exists($table_des->{$_}->{'name'})) { - $text .=$table_des->{$_}->{'name'}; + # + foreach my $indextype ('KEY','INDEX') { + next if (!exists($table_des->{$indextype})); + foreach my $indexdescription (@{$table_des->{$indextype}}) { + my $text = $indextype.' '; + if (exists($indexdescription->{'name'})) { + $text .=$indexdescription->{'name'}; } - $text .= ' ('.join(',',@{$table_des->{$_}->{'columns'}}).')'; + $text .= ' ('.join(',',@{$indexdescription->{'columns'}}).')'; push (@Columns,$text); } } - foreach ('UNIQUE','FULLTEXT') { - if (exists($table_des->{$_})) { - my $text = $_.' '; - if (exists($table_des->{$_}->{'index'}) && - $table_des->{$_}->{'index'} eq 'yes') { + # + foreach my $indextype ('UNIQUE','FULLTEXT') { + next if (! exists($table_des->{$indextype})); + foreach my $indexdescription (@{$table_des->{$indextype}}) { + my $text = $indextype.' '; + if (exists($indexdescription->{'index'}) && + $indexdescription->{'index'} eq 'yes') { $text .= 'INDEX '; } - if (exists($table_des->{$_}->{'name'})) { - $text .=$table_des->{$_}->{'name'}; + if (exists($indexdescription->{'name'})) { + $text .=$indexdescription->{'name'}; } - $text .= ' ('.join(',',@{$table_des->{$_}->{'columns'}}).')'; + $text .= ' ('.join(',',@{$indexdescription->{'columns'}}).')'; push (@Columns,$text); } } + # $request .= "(".join(", ",@Columns).") "; unless($table_des->{'permanent'} eq 'yes') { $request.="COMMENT = 'temporary' "; @@ -956,6 +981,7 @@ sub remove_from_table { $errorstring = "ERROR on execution of ".$command."\n".$sth->errstr; return undef; } + $debugstring = $command; my $rows = $sth->rows; return $rows; }