From e39ed5d76fea4b6247db0db8d878cb2209e44455 Mon Sep 17 00:00:00 2001 From: Monty Date: Sat, 9 Sep 2023 15:14:28 +0300 Subject: [PATCH] Updated sql-bench to run with PostgreSQL 14.9 - Updated capabilities for PostgreSQL in server.cfg - Updated test-ATIS & test-table-elimination to work with PostgreSQL - Updated test-transaction test to also work with non transactional tables Other things: - Added test of tables with many keys in test-insert - Added 2 new GROUP BY .. ORDER BY test --- .gitignore | 1 + sql-bench/run-all-tests.sh | 2 +- sql-bench/server-cfg.sh | 111 ++++++----------- sql-bench/test-ATIS.sh | 4 +- sql-bench/test-insert.sh | 186 +++++++++++++++++++++++++++- sql-bench/test-select.sh | 25 +++- sql-bench/test-table-elimination.sh | 20 +-- sql-bench/test-transactions.sh | 25 ++-- 8 files changed, 267 insertions(+), 107 deletions(-) diff --git a/.gitignore b/.gitignore index fdba73a3edb..22de4d2b2ee 100644 --- a/.gitignore +++ b/.gitignore @@ -186,6 +186,7 @@ sql-bench/innotest1b.pl sql-bench/innotest2.pl sql-bench/innotest2a.pl sql-bench/innotest2b.pl +sql-bench/output sql-bench/run-all-tests.pl sql-bench/server-cfg.pl sql-bench/test-ATIS.pl diff --git a/sql-bench/run-all-tests.sh b/sql-bench/run-all-tests.sh index ecab48e88fe..d600541cbc4 100644 --- a/sql-bench/run-all-tests.sh +++ b/sql-bench/run-all-tests.sh @@ -25,7 +25,7 @@ # All options to this script is passed to all test program. # useful options: # --fast --force --lock-tables -# --server ==> mysql (default) / mSQL / Pg (postgres) / Solid +# --server ==> mariadb (default) / mysql / Pg (postgres) / Oracle # --user ==> the user with permission to create / drop / select # --pass ==> password for the user # --cmp ==> Compare --server with one of the others (mysql/mSQL/Pg/Solid) diff --git a/sql-bench/server-cfg.sh b/sql-bench/server-cfg.sh index f0fca1d2f01..c7a45f888d5 100644 --- a/sql-bench/server-cfg.sh +++ b/sql-bench/server-cfg.sh @@ -37,7 +37,7 @@ sub get_server { my ($name,$host,$database,$odbc,$machine,$socket,$connect_options)=@_; my ($server); - if ($name =~ /mysql/i) + if ($name =~ /mysql/i || $name =~ /mariadb/i) { $server=new db_MySQL($host, $database, $machine, $socket,$connect_options); } elsif ($name =~ /pg/i) { $server= new db_Pg($host,$database); } @@ -77,7 +77,7 @@ sub get_server { $server= new db_interbase($host,$database); } else { - die "Unknown sql server name used: $name\nUse one of: Access, Adabas, AdabasD, Empress, FrontBase, Oracle, Informix, InterBase, DB2, mSQL, Mimer, MS-SQL, MySQL, Pg, Solid, SAPDB or Sybase.\nIf the connection is done trough ODBC the name must end with _ODBC\n"; + die "Unknown sql server name used: $name\nUse one of: Access, Adabas, AdabasD, Empress, FrontBase, Oracle, Informix, InterBase, DB2, mSQL, MariaDB, Mimer, MS-SQL, MySQL, Pg, Solid, SAPDB or Sybase.\nIf the connection is done trough ODBC the name must end with _ODBC\n"; } if ($name =~ /_ODBC$/i || defined($odbc) && $odbc) { @@ -98,12 +98,12 @@ sub get_server sub all_servers { return ["Access", "Adabas", "DB2", "Empress", "FrontBase", "Oracle", - "Informix", "InterBase", "Mimer", "mSQL", "MS-SQL", "MySQL", "Pg","SAPDB", - "Solid", "Sybase"]; + "Informix", "InterBase", "MariaDB", "Mimer", "mSQL", "MS-SQL", "MySQL", + "Pg","SAPDB", "Solid", "Sybase"]; } ############################################################################# -# First the configuration for MySQL off course :-) +# First the configuration for MariaDB / MySQL off course :-) ############################################################################# package db_MySQL; @@ -165,6 +165,7 @@ sub new $limits{'max_text_size'} = 1000000; # Good enough for tests $limits{'multi_drop'} = 1; # Drop table can take many tables $limits{'order_by_position'} = 1; # Can use 'ORDER BY 1' + $limits{'order_by_null'} = 1; # Can use 'ORDER BY NULL' $limits{'order_by_unused'} = 1; $limits{'query_size'} = 1000000; # Max size with default buffers. $limits{'select_without_from'}= 1; # Can do 'select 1'; @@ -224,7 +225,7 @@ sub version if ($sth->execute && (@row = $sth->fetchrow_array)) { $row[0] =~ s/-/ /g; # To get better tables with long names - $version="MySQL $row[0]"; + $version="$row[0]"; } $sth->finish; @@ -283,7 +284,6 @@ sub create } foreach $field (@$fields) { -# $field =~ s/ decimal/ double(10,2)/i; $field =~ s/ big_decimal/ double(10,2)/i; $query.= $field . ','; } @@ -604,12 +604,14 @@ sub new $self->{'transactions'} = 1; # Transactions enabled $self->{"vacuum"} = 1; $limits{'join_optimizer'} = 1; # Can optimize FROM tables + # load_data_infile could use function 'insert_file', but I could not get it to + # work because of permissions problems. Disabling for now. $limits{'load_data_infile'} = 0; - $limits{'NEG'} = 1; - $limits{'alter_add_multi_col'}= 0; # alter_add_multi_col ? + $limits{'alter_add_multi_col'}= 1; $limits{'alter_table'} = 1; - $limits{'alter_table_dropcol'}= 0; + $limits{'alter_table_dropcol'}= 1; + $limits{'alter_table_after'} = 0; # Have ALTER TABLE .. AFTER other_column $limits{'column_alias'} = 1; $limits{'func_extra_%'} = 1; $limits{'func_extra_if'} = 0; @@ -649,7 +651,7 @@ sub new $limits{'working_all_fields'} = 1; $limits{'working_blobs'} = 1; # If big varchar/blobs works $limits{'multi_distinct'} = 1; # allows select count(distinct a),count(distinct b).. - + $limits{'insert_multi_value'} = 1; # Have INSERT ... values (1,2),(3,4) return $self; } @@ -657,21 +659,20 @@ sub new sub version { - my ($version,$dir); - $version = "PostgreSQL version ???"; - foreach $dir ($ENV{'PGDATA'},"/usr/local/pgsql/data", "/usr/local/pg/data") + my ($self)=@_; + my ($dbh,$sth,$version,@row); + + $dbh=$self->connect(); + $sth = $dbh->prepare("select VERSION()") or die $DBI::errstr; + $version="PostgreSQL ?"; + if ($sth->execute && (@row = $sth->fetchrow_array)) { - if ($dir && -e "$dir/PG_VERSION") - { - $version= `cat $dir/PG_VERSION`; - if ($? == 0) - { - chomp($version); - $version .= "/ODBC" if ($self->{'data_source'} =~ /:ODBC:/); - return "PostgreSQL $version"; - } - } + $row[0] =~ s/-/ /g; # To get better tables with long names + $version="PostgreSQL $row[0]"; } + $sth->finish; + + $dbh->disconnect; $version .= "/ODBC" if ($self->{'data_source'} =~ /:ODBC:/); return $version; } @@ -707,9 +708,6 @@ sub create $field =~ s/int\(\d*\)/int/; $field =~ s/float\(\d*,\d*\)/float/; $field =~ s/ double/ float/; -# $field =~ s/ decimal/ float/i; -# $field =~ s/ big_decimal/ float/i; -# $field =~ s/ date/ int/i; # Pg doesn't have blob, it has text instead $field =~ s/ blob/ text/; $query.= $field . ','; @@ -718,13 +716,14 @@ sub create push(@queries,$query); foreach $index (@$index) { - $index =~ s/primary key/unique index primary_key/i; - if ($index =~ /^unique.*\(([^\(]*)\)$/i) + if ($index =~ /primary key/ || $index =~ /PRIMARY KEY/) { - # original: $indfield="using btree (" .$1.")"; - # using btree doesnīt seem to work with Postgres anymore; it creates - # the table and adds the index, but it isnīt unique - $indfield=" (" .$1.")"; + $query= substr($query, 0, length($query)-1) . ", $index )"; + next; + } + elsif ($index =~ /^unique.*\(([^\(]*)\)$/i) + { + $indfield=" (" .$1.")"; $in="unique index"; $table="index_$nr"; $nr++; } @@ -752,52 +751,14 @@ sub insert_file { # Syntax: # copy [binary] [with oids] # {to|from} {|stdin|stdout} [using delimiters ] - print "The ascii files aren't correct for postgres ....!!!\n"; - $command = "copy $dbname from '$file' using delimiters ','"; + $command = "copy $dbname from '$file' using delimiters ',' QUOTE ''''"; print "$command\n"; $sth = $dbh->do($command) or die $DBI::errstr; return $sth; } -# -# As postgreSQL wants A % B instead of standard mod(A,B) we have to map -# This will not handle all cases, but as the benchmarks doesn't use functions -# inside MOD() the following should work -# -# PostgreSQL cant handle count(*) or even count(1), but it can handle -# count(1+1) sometimes. ==> this is solved in PostgreSQL 6.3 -# -# PostgreSQL 6.5 is supporting MOD. - sub query { my($self,$sql) = @_; - my(@select,$change); -# if you use PostgreSQL 6.x and x is lower as 5 then uncomment the line below. -# $sql =~ s/mod\(([^,]*),([^\)]*)\)/\($1 % $2\)/gi; -# -# if you use PostgreSQL 6.1.x uncomment the lines below -# if ($sql =~ /select\s+count\(\*\)\s+from/i) { -# } -# elsif ($sql =~ /count\(\*\)/i) -# { -# if ($sql =~ /select\s+(.*)\s+from/i) -# { -# @select = split(/,/,$1); -# if ($select[0] =~ /(.*)\s+as\s+\w+$/i) -# { -# $change = $1; -# } -# else -# { -# $change = $select[0]; -# } -# } -# if (($change =~ /count/i) || ($change eq "")) { -# $change = "1+1"; -# } -# $sql =~ s/count\(\*\)/count($change)/gi; -# } -# till here. return $sql; } @@ -849,10 +810,8 @@ sub vacuum } else { -# $dbh->do("vacuum pg_attributes") || die "Got error: $DBI::errstr when executing 'vacuum'\n"; -# $dbh->do("vacuum pg_index") || die "Got error: $DBI::errstr when executing 'vacuum'\n"; - $dbh->do("vacuum analyze") || die "Got error: $DBI::errstr when executing 'vacuum analyze'\n"; - $dbh->do("vacuum") || die "Got error: $DBI::errstr when executing 'vacuum'\n"; + $dbh->do("vacuum analyze") || die "Got error: $DBI::errstr when executing 'vacuum analyze'\n"; + $dbh->do("vacuum") || die "Got error: $DBI::errstr when executing 'vacuum'\n"; } $end_time=new Benchmark; print "Time for book-keeping (1): " . diff --git a/sql-bench/test-ATIS.sh b/sql-bench/test-ATIS.sh index c51688de0c2..2eca4bed7dc 100644 --- a/sql-bench/test-ATIS.sh +++ b/sql-bench/test-ATIS.sh @@ -220,7 +220,7 @@ print "Retrieving data\n"; "select category,count(*) from aircraft where engines=2 group by category having count(*)>4",3,$limits->{'group_functions'} && $limits->{'having_with_group'}, "select flight_number,range_miles,fare_class FROM aircraft,flight,flight_class WHERE flight.flight_code=flight_class.flight_code AND flight.aircraft_code=aircraft.aircraft_code AND range_miles<>0 AND (stops=1 OR stops=2) GROUP BY flight_number,range_miles,fare_class",150,$limits->{'group_functions'}, "select distinct from_airport.time_zone_code,to_airport.time_zone_code,(FLOOR(arrival_time/100)*60+MOD(arrival_time,100)-FLOOR(departure_time/100)*60-MOD(departure_time,100)-time_elapsed)/60 AS time_zone_diff FROM flight,airport AS from_airport,airport AS to_airport WHERE flight.from_airport=from_airport.airport_code AND flight.to_airport=to_airport.airport_code GROUP BY from_airport.time_zone_code,to_airport.time_zone_code,arrival_time,departure_time,time_elapsed",21,$limits->{'func_odbc_mod'} && $limits->{'func_odbc_floor'} && $limits->{'group_functions'}, - "select DISTINCT from_airport.time_zone_code,to_airport.time_zone_code,MOD((FLOOR(arrival_time/100)*60+MOD(arrival_time,100)-FLOOR(departure_time/100)*60-MOD(departure_time,100)-time_elapsed)/60+36,24)-12 AS time_zone_diff FROM flight,airport AS from_airport,airport AS to_airport WHERE flight.from_airport=from_airport.airport_code AND flight.to_airport=to_airport.airport_code and MOD((FLOOR(arrival_time/100)*60+MOD(arrival_time,100)-FLOOR(departure_time/100)*60-MOD(departure_time,100)-time_elapsed)/60+36,24)-12 < 10",14,$limits->{'func_odbc_mod'} && $limits->{'func_odbc_floor'} && $limits->{'group_functions'}, + "select DISTINCT from_airport.time_zone_code,to_airport.time_zone_code,MOD(CAST((FLOOR(arrival_time/100)*60+MOD(arrival_time,100)-FLOOR(departure_time/100)*60-MOD(departure_time,100)-time_elapsed)/60+36 AS INTEGER),24)-12 AS time_zone_diff FROM flight,airport AS from_airport,airport AS to_airport WHERE flight.from_airport=from_airport.airport_code AND flight.to_airport=to_airport.airport_code and MOD(CAST((FLOOR(arrival_time/100)*60+MOD(arrival_time,100)-FLOOR(departure_time/100)*60-MOD(departure_time,100)-time_elapsed)/60+36 AS INTEGER),24)-12 < 10",14,$limits->{'func_odbc_mod'} && $limits->{'func_odbc_floor'} && $limits->{'group_functions'}, "select from_airport,to_airport,range_miles,time_elapsed FROM aircraft,flight WHERE aircraft.aircraft_code=flight.aircraft_code AND to_airport NOT LIKE from_airport AND range_miles<>0 AND time_elapsed<>0 GROUP BY from_airport,to_airport,range_miles,time_elapsed",409,$limits->{'group_functions'} && $limits->{'like_with_column'}, "SELECT airport.country_name,state.state_name,city.city_name,airport_service.direction FROM airport_service,state,airport,city WHERE airport_service.city_code=city.city_code AND airport_service.airport_code=airport.airport_code AND state.state_code=airport.state_code AND state.state_code=city.state_code AND airport.state_code=city.state_code AND airport.country_name=city.country_name AND airport.country_name=state.country_name AND city.time_zone_code=airport.time_zone_code GROUP BY airport.country_name,state.state_name,city.city_name,airport_service.direction ORDER BY state_name",11,$limits->{'group_functions'}, "SELECT airport.country_name,state.state_name,city.city_name,airport_service.direction FROM airport_service,state,airport,city WHERE airport_service.city_code=city.city_code AND airport_service.airport_code=airport.airport_code AND state.state_code=airport.state_code AND state.state_code=city.state_code AND airport.state_code=city.state_code AND airport.country_name=city.country_name AND airport.country_name=state.country_name AND city.time_zone_code=airport.time_zone_code GROUP BY airport.country_name,state.state_name,city.city_name,airport_service.direction ORDER BY state_name DESC",11,$limits->{'group_functions'}, @@ -369,7 +369,7 @@ sub init_data @class_of_service= $server->create("class_of_service", ["class_code char(2) NOT NULL", - "`rank` tinyint(2) NOT NULL", + "rank tinyint(2) NOT NULL", "class_description char(80) NOT NULL"], ["PRIMARY KEY (class_code)"]); @code_description= diff --git a/sql-bench/test-insert.sh b/sql-bench/test-insert.sh index dbdc58fdcca..5aee14dc47e 100644 --- a/sql-bench/test-insert.sh +++ b/sql-bench/test-insert.sh @@ -39,6 +39,7 @@ $small_loop_count=10; # Loop for full table retrieval $range_loop_count=$small_loop_count*50; $many_keys_loop_count=$opt_loop_count; $opt_read_key_loop_count=$opt_loop_count; +$many_key_update=10000; $pwd = cwd(); $pwd = "." if ($pwd eq ''); require "$pwd/bench-init.pl" || die "Can't read Configuration file: $!\n"; @@ -49,16 +50,19 @@ if ($opt_small_test) $many_keys_loop_count=$opt_loop_count/10; $range_loop_count=10; $opt_read_key_loop_count=10; + $many_key_update=10; } elsif ($opt_small_tables) { $opt_loop_count=10000; # number of rows/3 $many_keys_loop_count=$opt_loop_count; $opt_read_key_loop_count=10; + $many_key_update=10; } elsif ($opt_small_key_tables) { $many_keys_loop_count/=10; + $many_key_update/=10; } if ($opt_loop_count < 100) @@ -101,13 +105,16 @@ $dbh = $server->connect(); #### Create needed tables #### -goto keys_test if ($opt_stage == 2); goto select_test if ($opt_skip_create); -print "Creating tables\n"; $dbh->do("drop table bench1" . $server->{'drop_attr'}); $dbh->do("drop table bench2" . $server->{'drop_attr'}); $dbh->do("drop table bench3" . $server->{'drop_attr'}); + +goto keys_test if ($opt_stage == 2); +goto keys_test2 if ($opt_stage == 3); + +print "Creating tables\n"; do_many($dbh,$server->create("bench1", ["id int NOT NULL", "id2 int NOT NULL", @@ -1590,6 +1597,181 @@ if ($limits->{'insert_multi_value'}) timestr(timediff($end_time, $loop_time),"all") . "\n\n"; } +# +# Test insert and update on a table with a lot of different keys +# + +keys_test2: + +$keys=min($limits->{'max_index'},8); # 8 is more than enough +print "Insert into table with $many_keys_loop_count rows, $keys keys and with simple primary key\n"; + +@fields=(); +@keys=(); + +# Make keys on the most important types +@types=(0,0,1,1,0,0,1,1,1,1,1,1,1,1,1,1); # A 1 for each char field +push(@fields,"field1 integer not null"); +push(@fields,"field2 integer not null"); +push(@fields,"field3 char(16) not null"); +push(@fields,"field4 varchar(64) not null"); +push(@fields,"field5 float not null"); +push(@fields,"field6 double not null"); +push(@fields,"field7 integer not null"); +for ($i=8 ; $i <= 16 ; $i++) +{ + push(@fields,"field$i varchar(16) not null"); +} + +$query="primary key (field1) "; +push (@keys,$query); +# Create other keys +for ($i=2 ; $i <= $keys ; $i++) +{ + push(@keys,"index index$i (field$i)"); +} + +do_many($dbh,$server->create("bench1",\@fields,\@keys)); +if ($opt_lock_tables) +{ + $dbh->do("LOCK TABLES bench1 WRITE") || die $DBI::errstr; +} + +$loop_time=new Benchmark; +if ($opt_fast && $server->{transactions}) +{ + $dbh->{AutoCommit} = 0; +} + +$fields=$#fields+1; +if (($opt_fast || $opt_fast_insert) && $server->{'limits'}->{'insert_multi_value'}) +{ + $query_size=$server->{'limits'}->{'query_size'}; + $query="insert into bench1 values "; + $res=$query; + for ($i=1; $i <= $many_keys_loop_count; $i++) + { + $id= $i; + $rand=$random[$i]; + $tmp="($id,$id,'test$rand','ABCDEF$rand',$rand.0,$rand.0,$rand,"; + + for ($j=8; $j <= $fields ; $j++) + { + $tmp.= ($types[$j] == 0) ? "$rand," : "'$rand',"; + } + substr($tmp,-1)=")"; + if (length($tmp)+length($res) < $query_size) + { + $res.= $tmp . ","; + } + else + { + $sth = $dbh->do(substr($res,0,length($res)-1)) or die "$DBI::errstr"; + $res=$query . $tmp . ","; + } + } + $sth = $dbh->do(substr($res,0,length($res)-1)) or die $DBI::errstr; +} +else +{ + for ($i=1; $i <= $many_keys_loop_count; $i++) + { + $id= $i; + $rand=$random[$i]; + + + $query="insert into bench1 values ($id,$id,'test$rand','ABCDEF$rand',$rand.0,$rand.0,$rand,"; + + for ($j=8; $j <= $fields ; $j++) + { + $query.= ($types[$j] == 0) ? "$rand," : "'$rand',"; + } + substr($query,-1)=")"; + print "query1: $query\n" if ($opt_debug); + $dbh->do($query) or die "Got error $DBI::errstr with query: $query\n"; + } +} + +if ($opt_fast && $server->{transactions}) +{ + $dbh->commit; + $dbh->{AutoCommit} = 1; +} + +$end_time=new Benchmark; +print "Time for insert_many_keys ($many_keys_loop_count): " . + timestr(timediff($end_time, $loop_time),"all") . "\n\n"; + +if ($opt_fast && defined($server->{vacuum})) +{ + if ($opt_lock_tables) + { + do_query($dbh,"UNLOCK TABLES"); + } + + $server->vacuum(1,\$dbh,"bench1"); + if ($opt_lock_tables) + { + $sth = $dbh->do("LOCK TABLES bench1 WRITE") || die $DBI::errstr; + } +} + +# +# Testing of update of table with many keys +# + +$loop_time=new Benchmark; +for ($i=0 ; $i< $many_key_update; $i++) +{ + $tmp= ($i*11 % $many_keys_loop_count)+1; + $query="update bench1 set field7=$i where field1=$tmp"; + $dbh->do($query) or die "Got error $DBI::errstr with query $query\n"; +} +$end_time=new Benchmark; +print "Time for many_key_update_of_key_with_primary ($many_key_update): " . + timestr(timediff($end_time, $loop_time),"all") . "\n\n"; + +$loop_time=new Benchmark; +for ($i=0 ; $i< $many_key_update; $i++) +{ + $tmp= ($i*11 % $many_keys_loop_count)+1; + $query="update bench1 set field7=$i+1 where field2=$tmp"; + $dbh->do($query) or die "Got error $DBI::errstr with query $query\n"; +} +$end_time=new Benchmark; +print "Time for many_key_update_of_key_with_secondary ($many_key_update): " . + timestr(timediff($end_time, $loop_time),"all") . "\n\n"; + +$loop_time=new Benchmark; +for ($i=0 ; $i< $many_key_update; $i++) +{ + $tmp= ($i*11 % $many_keys_loop_count)+2; + $query="update bench1 set field8='hello', field9='world' where field1=$tmp"; + $dbh->do($query) or die "Got error $DBI::errstr with query $query\n"; +} +$end_time=new Benchmark; +print "Time for many_key_update_of_field_with_primary ($many_key_update): " . + timestr(timediff($end_time, $loop_time),"all") . "\n\n"; + +$loop_time=new Benchmark; +for ($i=0 ; $i< $many_key_update; $i++) +{ + $tmp= ($i*11 % $many_keys_loop_count)+3; + $query="update bench1 set field8='world', field9='hello' where field2=$tmp"; + $dbh->do($query) or die "Got error $DBI::errstr with query $query\n"; +} +$end_time=new Benchmark; +print "Time for many_key_update_of_field_with_secondary ($many_key_update): " . + timestr(timediff($end_time, $loop_time),"all") . "\n\n"; + + +$loop_time=new Benchmark; +$sth = $dbh->do("drop table bench1" . $server->{'drop_attr'}) or die $DBI::errstr; +$end_time=new Benchmark; +print "Time for drop table(1): " . + timestr(timediff($end_time, $loop_time),"all") . "\n\n"; + + #### #### End of benchmark #### diff --git a/sql-bench/test-select.sh b/sql-bench/test-select.sh index e3020698cb8..fefc860e6ef 100644 --- a/sql-bench/test-select.sh +++ b/sql-bench/test-select.sh @@ -336,6 +336,29 @@ if ($limits->{'group_functions'}) print "Time for count_group ($i:$rows): " . timestr(timediff($end_time, $loop_time),"all") . "\n"; + $loop_time=new Benchmark; + $rows=0; + for ($i=0 ; $i < $opt_medium_loop_count ; $i++) + { + $rows+=fetch_all_rows($dbh,"select grp_no_key,count(*) from bench1 group by grp_no_key order by grp_no_key"); + } + $end_time=new Benchmark; + + print "Time for count_group_order_group ($i:$rows): " . + timestr(timediff($end_time, $loop_time),"all") . "\n"; + + if ($limits->{'order_by_null'}) + { + $loop_time=new Benchmark; + $rows=0; + for ($i=0 ; $i < $opt_medium_loop_count ; $i++) + { + $rows+=fetch_all_rows($dbh,"select grp_no_key,count(*) from bench1 group by grp_no_key order by null"); + } + $end_time=new Benchmark; + print "Time for count_group_order_null ($i:$rows): " . + timestr(timediff($end_time, $loop_time),"all") . "\n"; + } $loop_time=new Benchmark; $rows=0; for ($i=0 ; $i < $opt_medium_loop_count ; $i++) @@ -344,7 +367,7 @@ if ($limits->{'group_functions'}) } $end_time=new Benchmark; print "Time for count_group_with_order ($i:$rows): " . - timestr(timediff($end_time, $loop_time),"all") . "\n"; + timestr(timediff($end_time, $loop_time),"all") . "\n\n"; } if ($limits->{'group_distinct_functions'}) diff --git a/sql-bench/test-table-elimination.sh b/sql-bench/test-table-elimination.sh index c3a264492a4..0f5e53e00a4 100755 --- a/sql-bench/test-table-elimination.sh +++ b/sql-bench/test-table-elimination.sh @@ -34,18 +34,7 @@ $select_current_full_facts=" A2.fromdate=(select MAX(fromdate) from elim_attr2 where id=A2.id); "; -$select_current_full_facts=" - select - F.id, A1.attr1, A2.attr2 - from - elim_facts F - left join elim_attr1 A1 on A1.id=F.id - left join elim_attr2 A2 on A2.id=F.id and - A2.fromdate=(select MAX(fromdate) from - elim_attr2 where id=F.id); -"; -# TODO: same as above but for some given date also? -# TODO: +# TODO: same as above but for some given date also? #### @@ -62,6 +51,7 @@ $start_time=new Benchmark; goto select_test if ($opt_skip_create); print "Creating tables\n"; +$dbh->do("drop view elim_current_facts"); $dbh->do("drop table elim_facts" . $server->{'drop_attr'}); $dbh->do("drop table elim_attr1" . $server->{'drop_attr'}); $dbh->do("drop table elim_attr2" . $server->{'drop_attr'}); @@ -76,7 +66,7 @@ do_many($dbh,$server->create("elim_attr1", ["id integer", "attr1 integer"], ["primary key (id)", - "key (attr1)"])); + "index ix_attr1 (attr1)"])); # Attribute2, time-versioned do_many($dbh,$server->create("elim_attr2", @@ -84,7 +74,7 @@ do_many($dbh,$server->create("elim_attr2", "attr2 integer", "fromdate date"], ["primary key (id, fromdate)", - "key (attr2,fromdate)"])); + "index ix_attr2 (attr2,fromdate)"])); #NOTE: ignoring: if ($limits->{'views'}) $dbh->do("drop view elim_current_facts"); @@ -304,8 +294,8 @@ if ($opt_lock_tables) } if (!$opt_skip_delete) { - do_query($dbh,"drop table elim_facts, elim_attr1, elim_attr2" . $server->{'drop_attr'}); $dbh->do("drop view elim_current_facts"); + do_query($dbh,"drop table elim_facts, elim_attr1, elim_attr2" . $server->{'drop_attr'}); } if ($opt_fast && defined($server->{vacuum})) diff --git a/sql-bench/test-transactions.sh b/sql-bench/test-transactions.sh index 334a6f0a385..1b88b258d90 100644 --- a/sql-bench/test-transactions.sh +++ b/sql-bench/test-transactions.sh @@ -45,13 +45,6 @@ if ($opt_small_test || $opt_small_tables) $opt_medium_loop_count/=10; } - -if (!$server->{transactions} && !$opt_force) -{ - print "Test skipped because the database doesn't support transactions\n"; - exit(0); -} - #### #### Connect and start timeing #### @@ -90,7 +83,10 @@ $dbh->{AutoCommit} = 0; ### Test insert perfomance ### -test_insert("bench1","insert_commit",0); +if ($server->{transactions}) +{ + test_insert("bench1","insert_commit",0); +} test_insert("bench2","insert_autocommit",1); sub test_insert @@ -130,6 +126,7 @@ print "Test transactions rollback performance\n" if($opt_debug); # then doing a rollback on these # +if ($server->{transactions}) { my ($id,$rev_id,$grp,$region,$end,$loop_time,$end_time,$commit_loop,$count); @@ -171,6 +168,7 @@ print "Test transactions rollback performance\n" if($opt_debug); # then doing a rollback on these # +if ($server->{transactions}) { my ($id,$loop_time,$end_time,$commit_loop,$count); @@ -208,6 +206,7 @@ print "Test transactions rollback performance\n" if($opt_debug); # then doing a rollback on these # +if ($server->{transactions}) { my ($id,$loop_time,$end_time,$commit_loop,$count); @@ -241,7 +240,10 @@ print "Test transactions rollback performance\n" if($opt_debug); ### Test update perfomance ### -test_update("bench1","update_commit",0); +if ($server->{transactions}) +{ + test_update("bench1","update_commit",0); +} test_update("bench2","update_autocommit",1); sub test_update @@ -267,7 +269,10 @@ sub test_update ### Test delete perfomance ### -test_delete("bench1","delete_commit",0); +if ($server->{transactions}) +{ + test_delete("bench1","delete_commit",0); +} test_delete("bench2","delete_autocommit",1); sub test_delete