2007-02-06 13:35:54 +01:00
|
|
|
eval create table t1 (a float not null, primary key(a)) engine=$engine
|
|
|
|
partition by key (a) (
|
2008-02-06 15:13:56 +01:00
|
|
|
partition pa1 max_rows=20 min_rows=2,
|
|
|
|
partition pa2 max_rows=30 min_rows=3,
|
|
|
|
partition pa3 max_rows=30 min_rows=4,
|
|
|
|
partition pa4 max_rows=40 min_rows=2);
|
2007-02-06 13:35:54 +01:00
|
|
|
show create table t1;
|
|
|
|
insert into t1 values (-3.402823466E+38), (3.402823466E+38), (-1.5), (-1), (0), (1), (1.5);
|
|
|
|
select * from t1;
|
|
|
|
select * from t1 where a=1.5;
|
|
|
|
delete from t1 where a=1.5;
|
|
|
|
select * from t1;
|
|
|
|
drop table t1;
|
|
|
|
|
|
|
|
eval create table t2 (a float not null, primary key(a)) engine=$engine
|
|
|
|
partition by key (a) partitions 10;
|
|
|
|
show create table t2;
|
|
|
|
insert into t2 values (-3.402823466E+38), (-3.402823466E+37), (-123.456), (0), (1234546.789), (123.456), (1.5);
|
|
|
|
select * from t2;
|
|
|
|
#result set is empty: Not a bug with float!!
|
|
|
|
select * from t2 where a=123.456;
|
|
|
|
delete from t2 where a=123.456;
|
|
|
|
select * from t2;
|
|
|
|
select * from t2 where a=1.5;
|
|
|
|
delete from t2 where a=1.5;
|
|
|
|
select * from t2;
|
|
|
|
delete from t2;
|
|
|
|
let $count=$maxrows;
|
|
|
|
--echo $maxrows*3 inserts;
|
|
|
|
--disable_query_log
|
|
|
|
while ($count)
|
|
|
|
{
|
|
|
|
eval insert into t2 values ($count);
|
|
|
|
eval insert into t2 values ($count+0.33);
|
|
|
|
eval insert into t2 values ($count+0.75);
|
|
|
|
dec $count;
|
|
|
|
}
|
|
|
|
--enable_query_log
|
|
|
|
select count(*) from t2;
|
|
|
|
drop table t2;
|
|
|
|
|
2007-08-27 14:08:32 -06:00
|
|
|
# Bug 30577: FLOOR() and CEILING() not usable as partition functions
|
|
|
|
# Partition functions are required to return INT_RESULT; FLOOR() and
|
|
|
|
# CEILING() do not, unless they have an INT argument. Disable this
|
|
|
|
# portion of the test until bug 30577 is fixed.
|
|
|
|
|
|
|
|
--disable_parsing
|
|
|
|
|
2007-02-06 13:35:54 +01:00
|
|
|
eval create table t3 (a float not null, primary key(a)) engine=$engine
|
2007-08-27 14:08:32 -06:00
|
|
|
partition by range (floor(a)) subpartition by key (a) subpartitions 3 (
|
2007-02-06 13:35:54 +01:00
|
|
|
partition pa1 values less than (3),
|
|
|
|
partition pa3 values less than (6),
|
|
|
|
partition pa10 values less than (10)
|
|
|
|
);
|
|
|
|
show create table t3;
|
|
|
|
let $count=9;
|
|
|
|
--echo $count*3 inserts;
|
|
|
|
while ($count)
|
|
|
|
{
|
|
|
|
eval insert into t3 values ($count);
|
|
|
|
eval insert into t3 values ($count+0.33);
|
|
|
|
eval insert into t3 values ($count+0.75);
|
|
|
|
dec $count;
|
|
|
|
}
|
|
|
|
select count(*) from t3;
|
|
|
|
select * from t3;
|
|
|
|
drop table t3;
|
|
|
|
|
|
|
|
eval create table t4 (a float not null, primary key(a)) engine=$engine
|
2007-08-27 14:08:32 -06:00
|
|
|
partition by list (floor(a)) subpartition by key (a) subpartitions 3 (
|
2007-02-06 13:35:54 +01:00
|
|
|
partition pa1 values in (1,2,3),
|
|
|
|
partition pa3 values in (4,5,6),
|
|
|
|
partition pa10 values in (7,8,9,10)
|
|
|
|
);
|
|
|
|
show create table t4;
|
|
|
|
let $count=9;
|
|
|
|
--echo $count*3 inserts;
|
|
|
|
while ($count)
|
|
|
|
{
|
|
|
|
eval insert into t4 values ($count);
|
|
|
|
eval insert into t4 values ($count+0.33);
|
|
|
|
eval insert into t4 values ($count+0.75);
|
|
|
|
dec $count;
|
|
|
|
}
|
|
|
|
select count(*) from t4;
|
|
|
|
select * from t4;
|
|
|
|
drop table t4;
|
2007-08-27 14:08:32 -06:00
|
|
|
|
|
|
|
# Disabled due to Bug 30577
|
|
|
|
--enable_parsing
|