mirror of
https://github.com/MariaDB/server.git
synced 2025-02-02 12:01:42 +01:00
f3dc047890
Test case fixes. mysql-test/r/binlog_multi_engine.result: Result change. mysql-test/r/rpl_ndb_stm_innodb.result: Result change. mysql-test/t/binlog_multi_engine.test: NDB tests only work in MIXED or ROW mode. Adding some cleanup actions. mysql-test/t/loaddata_autocom_ndb.test: NDB requires MIXED or ROW mode. mysql-test/t/ndb_alter_table.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_alter_table2.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_alter_table3.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_autodiscover.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_autodiscover2.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_autodiscover3.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_basic.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_binlog_log_bin.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_binlog_multi.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_bitfield.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_blob.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_blob_partition.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_cache.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_cache2.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_cache_multi.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_cache_multi2.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_charset.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_condition_pushdown.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_config.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_config2.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_cursor.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_database.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_dd_alter.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_dd_backuprestore.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_dd_basic.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_dd_ddl.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_dd_disk2memory.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_dd_dump.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_dd_sql_features.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_gis.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_index.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_index_ordered.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_index_unique.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_insert.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_limit.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_loaddatalocal.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_lock.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_minmax.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_multi.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_partition_error.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_partition_key.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_partition_list.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_partition_range.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_read_multi_range.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_rename.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_replace.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_restore.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_restore_partition.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_restore_print.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_row_format.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_single_user.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_sp.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_subquery.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_temporary.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_transaction.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_trigger.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_truncate.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_types.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_update.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndb_view.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ndbapi.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/ps_7ndb.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/rpl_ndb_commit_afterflush.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/rpl_ndb_innodb_trans.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode. mysql-test/t/rpl_ndb_stm_innodb.test: We need MIXED mode on slave since it is necessary to let the slave switch to row format when executing replicated statements. mysql-test/t/strict_autoinc_5ndb.test: NDB requires MIXED or ROW mode, but will switch to row format automatically, so we only run these tests under ROW mode.
481 lines
16 KiB
Text
481 lines
16 KiB
Text
-- source include/have_ndb.inc
|
|
-- source include/have_binlog_format_row.inc
|
|
-- source include/not_embedded.inc
|
|
|
|
--disable_warnings
|
|
drop table if exists t1, test1, test2;
|
|
--enable_warnings
|
|
|
|
#
|
|
# Simple test to show use of ordered indexes
|
|
#
|
|
|
|
CREATE TABLE t1 (
|
|
a int unsigned NOT NULL PRIMARY KEY,
|
|
b int unsigned not null,
|
|
c int unsigned,
|
|
KEY(b)
|
|
) engine=ndbcluster;
|
|
|
|
insert t1 values(1, 2, 3), (2,3, 5), (3, 4, 6), (4, 5, 8), (5,6, 2), (6,7, 2);
|
|
select * from t1 order by b;
|
|
select * from t1 where b >= 4 order by b;
|
|
select * from t1 where b = 4 order by b;
|
|
select * from t1 where b > 4 order by b;
|
|
select * from t1 where b < 4 order by b;
|
|
select * from t1 where b <= 4 order by b;
|
|
|
|
# Test of reset_bounds
|
|
select tt1.* from t1 as tt1, t1 as tt2 use index(b) where tt1.b = tt2.b order by tt1.b;
|
|
select a, b, c from t1 where a!=2 and c=6;
|
|
select a, b, c from t1 where a!=2 order by a;
|
|
|
|
#
|
|
# Here we should add some "explain select" to verify that the ordered index is
|
|
# used for these queries.
|
|
#
|
|
|
|
#
|
|
# Update using ordered index scan
|
|
#
|
|
|
|
update t1 set c = 3 where b = 3;
|
|
select * from t1 order by a;
|
|
update t1 set c = 10 where b >= 6;
|
|
select * from t1 order by a;
|
|
update t1 set c = 11 where b < 5;
|
|
select * from t1 order by a;
|
|
update t1 set c = 12 where b > 0;
|
|
select * from t1 order by a;
|
|
update t1 set c = 13 where b <= 3;
|
|
select * from t1 order by a;
|
|
update t1 set b = b + 1 where b > 4 and b < 7;
|
|
select * from t1 order by a;
|
|
# Update primary key
|
|
update t1 set a = a + 10 where b > 1 and b < 7;
|
|
select * from t1 order by a;
|
|
|
|
#
|
|
# Delete using ordered index scan
|
|
#
|
|
|
|
drop table t1;
|
|
|
|
CREATE TABLE t1 (
|
|
a int unsigned NOT NULL PRIMARY KEY,
|
|
b int unsigned not null,
|
|
c int unsigned,
|
|
KEY(b)
|
|
) engine=ndbcluster;
|
|
|
|
insert t1 values(1, 2, 13), (2,3, 13), (3, 4, 12), (4, 5, 12), (5,6, 12), (6,7, 12);
|
|
|
|
delete from t1 where b = 3;
|
|
select * from t1 order by a;
|
|
delete from t1 where b >= 6;
|
|
select * from t1 order by a;
|
|
delete from t1 where b < 4;
|
|
select * from t1 order by a;
|
|
delete from t1 where b > 5;
|
|
select * from t1 order by a;
|
|
delete from t1 where b <= 4;
|
|
select * from t1 order by a;
|
|
|
|
drop table t1;
|
|
|
|
|
|
#
|
|
#multi part key
|
|
#
|
|
CREATE TABLE t1 (
|
|
a int unsigned NOT NULL PRIMARY KEY,
|
|
b int unsigned not null,
|
|
c int unsigned not null
|
|
) engine = ndb;
|
|
|
|
create index a1 on t1 (b, c);
|
|
|
|
insert into t1 values (1, 2, 13);
|
|
insert into t1 values (2,3, 13);
|
|
insert into t1 values (3, 4, 12);
|
|
insert into t1 values (4, 5, 12);
|
|
insert into t1 values (5,6, 12);
|
|
insert into t1 values (6,7, 12);
|
|
insert into t1 values (7, 2, 1);
|
|
insert into t1 values (8,3, 6);
|
|
insert into t1 values (9, 4, 12);
|
|
insert into t1 values (14, 5, 4);
|
|
insert into t1 values (15,5,5);
|
|
insert into t1 values (16,5, 6);
|
|
insert into t1 values (17,4,4);
|
|
insert into t1 values (18,1, 7);
|
|
|
|
|
|
|
|
select * from t1 order by a;
|
|
select * from t1 where b<=5 order by a;
|
|
select * from t1 where b<=5 and c=0;
|
|
insert into t1 values (19,4, 0);
|
|
select * from t1 where b<=5 and c=0;
|
|
select * from t1 where b=4 and c<=5 order by a;
|
|
select * from t1 where b<=4 and c<=5 order by a;
|
|
select * from t1 where b<=5 and c=0 or b<=5 and c=2;
|
|
|
|
select count(*) from t1 where b = 0;
|
|
select count(*) from t1 where b = 1;
|
|
drop table t1;
|
|
|
|
#
|
|
# Indexing NULL values
|
|
#
|
|
|
|
CREATE TABLE t1 (
|
|
a int unsigned NOT NULL PRIMARY KEY,
|
|
b int unsigned,
|
|
c int unsigned,
|
|
KEY bc(b,c)
|
|
) engine = ndb;
|
|
|
|
insert into t1 values(1,1,1),(2,NULL,2),(3,NULL,NULL),(4,4,NULL);
|
|
select * from t1 use index (bc) where b IS NULL order by a;
|
|
|
|
select * from t1 use index (bc)order by a;
|
|
select * from t1 use index (bc) order by a;
|
|
select * from t1 use index (PRIMARY) where b IS NULL order by a;
|
|
select * from t1 use index (bc) where b IS NULL order by a;
|
|
select * from t1 use index (bc) where b IS NULL and c IS NULL order by a;
|
|
select * from t1 use index (bc) where b IS NULL and c = 2 order by a;
|
|
select * from t1 use index (bc) where b < 4 order by a;
|
|
select * from t1 use index (bc) where b IS NOT NULL order by a;
|
|
drop table t1;
|
|
|
|
#
|
|
# Order by again, including descending.
|
|
#
|
|
|
|
create table t1 (
|
|
a int unsigned primary key,
|
|
b int unsigned,
|
|
c char(10),
|
|
key bc (b, c)
|
|
) engine=ndb;
|
|
|
|
insert into t1 values(1,1,'a'),(2,2,'b'),(3,3,'c'),(4,4,'d'),(5,5,'e');
|
|
insert into t1 select a*7,10*b,'f' from t1;
|
|
insert into t1 select a*13,10*b,'g' from t1;
|
|
insert into t1 select a*17,10*b,'h' from t1;
|
|
insert into t1 select a*19,10*b,'i' from t1;
|
|
insert into t1 select a*23,10*b,'j' from t1;
|
|
insert into t1 select a*29,10*b,'k' from t1;
|
|
#
|
|
select b, c from t1 where b <= 10 and c <'f' order by b, c;
|
|
select b, c from t1 where b <= 10 and c <'f' order by b desc, c desc;
|
|
#
|
|
select b, c from t1 where b=4000 and c<'k' order by b, c;
|
|
select b, c from t1 where b=4000 and c<'k' order by b desc, c desc;
|
|
select b, c from t1 where 1000<=b and b<=100000 and c<'j' order by b, c;
|
|
select b, c from t1 where 1000<=b and b<=100000 and c<'j' order by b desc, c desc;
|
|
#
|
|
select min(b), max(b) from t1;
|
|
#
|
|
drop table t1;
|
|
|
|
#
|
|
# Bug #6435
|
|
CREATE TABLE test1 (
|
|
SubscrID int(11) NOT NULL auto_increment,
|
|
UsrID int(11) NOT NULL default '0',
|
|
PRIMARY KEY (SubscrID),
|
|
KEY idx_usrid (UsrID)
|
|
) ENGINE=ndbcluster DEFAULT CHARSET=latin1;
|
|
|
|
INSERT INTO test1 VALUES (2,224),(3,224),(1,224);
|
|
|
|
CREATE TABLE test2 (
|
|
SbclID int(11) NOT NULL auto_increment,
|
|
SbcrID int(11) NOT NULL default '0',
|
|
PRIMARY KEY (SbclID),
|
|
KEY idx_sbcrid (SbcrID)
|
|
) ENGINE=ndbcluster DEFAULT CHARSET=latin1;
|
|
|
|
INSERT INTO test2 VALUES (3,2),(1,1),(2,1),(4,2);
|
|
select * from test1 order by 1;
|
|
select * from test2 order by 1;
|
|
SELECT s.SubscrID,l.SbclID FROM test1 s left JOIN test2 l ON
|
|
l.SbcrID=s.SubscrID WHERE s.UsrID=224 order by 1, 2;
|
|
drop table test1;
|
|
drop table test2;
|
|
|
|
# bug#7424 + bug#7725
|
|
|
|
create table t1 (
|
|
pk int primary key,
|
|
dt datetime not null,
|
|
da date not null,
|
|
ye year not null,
|
|
ti time not null,
|
|
ts timestamp not null,
|
|
index(dt),
|
|
index(da),
|
|
index(ye),
|
|
index(ti),
|
|
index(ts)
|
|
) engine=ndb;
|
|
|
|
insert into t1 (pk,dt,da,ye,ti,ts) values
|
|
(1, '1901-05-05 23:00:59', '1901-05-05', '1901', '23:00:59', '2001-01-01 23:00:59'),
|
|
(2, '1912-09-05 13:00:59', '1912-09-05', '1912', '13:00:59', '2001-01-01 13:00:59'),
|
|
(3, '1945-12-31 00:00:00', '1945-12-31', '1945', '00:00:00', '2001-01-01 00:00:00'),
|
|
(4, '1955-12-31 00:00:00', '1955-12-31', '1955', '00:00:00', '2001-01-01 00:00:00'),
|
|
(5, '1963-06-06 06:06:06', '1963-06-06', '1963', '06:06:06', '2001-01-01 06:06:06'),
|
|
(6, '1993-06-06 06:06:06', '1993-06-06', '1993', '06:06:06', '2001-01-01 06:06:06'),
|
|
(7, '2001-01-01 10:11:10', '2001-01-01', '2001', '10:11:10', '2001-01-01 10:11:10'),
|
|
(8, '2001-01-01 10:11:11', '2001-01-01', '2001', '10:11:11', '2001-01-01 10:11:11'),
|
|
(9, '2005-01-31 23:59:59', '2005-01-31', '2005', '23:59:59', '2001-01-01 23:59:59');
|
|
|
|
# datetime
|
|
select count(*)-9 from t1 use index (dt) where dt > '1900-01-01 00:00:00';
|
|
select count(*)-6 from t1 use index (dt) where dt >= '1955-12-31 00:00:00';
|
|
select count(*)-5 from t1 use index (dt) where dt > '1955-12-31 00:00:00';
|
|
select count(*)-5 from t1 use index (dt) where dt < '1970-03-03 22:22:22';
|
|
select count(*)-7 from t1 use index (dt) where dt < '2001-01-01 10:11:11';
|
|
select count(*)-8 from t1 use index (dt) where dt <= '2001-01-01 10:11:11';
|
|
select count(*)-9 from t1 use index (dt) where dt <= '2055-01-01 00:00:00';
|
|
|
|
# date
|
|
select count(*)-9 from t1 use index (da) where da > '1900-01-01';
|
|
select count(*)-6 from t1 use index (da) where da >= '1955-12-31';
|
|
select count(*)-5 from t1 use index (da) where da > '1955-12-31';
|
|
select count(*)-5 from t1 use index (da) where da < '1970-03-03';
|
|
select count(*)-6 from t1 use index (da) where da < '2001-01-01';
|
|
select count(*)-8 from t1 use index (da) where da <= '2001-01-02';
|
|
select count(*)-9 from t1 use index (da) where da <= '2055-01-01';
|
|
|
|
# year
|
|
select count(*)-9 from t1 use index (ye) where ye > '1900';
|
|
select count(*)-6 from t1 use index (ye) where ye >= '1955';
|
|
select count(*)-5 from t1 use index (ye) where ye > '1955';
|
|
select count(*)-5 from t1 use index (ye) where ye < '1970';
|
|
select count(*)-6 from t1 use index (ye) where ye < '2001';
|
|
select count(*)-8 from t1 use index (ye) where ye <= '2001';
|
|
select count(*)-9 from t1 use index (ye) where ye <= '2055';
|
|
|
|
# time
|
|
select count(*)-9 from t1 use index (ti) where ti >= '00:00:00';
|
|
select count(*)-7 from t1 use index (ti) where ti > '00:00:00';
|
|
select count(*)-7 from t1 use index (ti) where ti > '05:05:05';
|
|
select count(*)-5 from t1 use index (ti) where ti > '06:06:06';
|
|
select count(*)-5 from t1 use index (ti) where ti < '10:11:11';
|
|
select count(*)-6 from t1 use index (ti) where ti <= '10:11:11';
|
|
select count(*)-8 from t1 use index (ti) where ti < '23:59:59';
|
|
select count(*)-9 from t1 use index (ti) where ti <= '23:59:59';
|
|
|
|
# timestamp
|
|
select count(*)-9 from t1 use index (ts) where ts >= '2001-01-01 00:00:00';
|
|
select count(*)-7 from t1 use index (ts) where ts > '2001-01-01 00:00:00';
|
|
select count(*)-7 from t1 use index (ts) where ts > '2001-01-01 05:05:05';
|
|
select count(*)-5 from t1 use index (ts) where ts > '2001-01-01 06:06:06';
|
|
select count(*)-5 from t1 use index (ts) where ts < '2001-01-01 10:11:11';
|
|
select count(*)-6 from t1 use index (ts) where ts <= '2001-01-01 10:11:11';
|
|
select count(*)-8 from t1 use index (ts) where ts < '2001-01-01 23:59:59';
|
|
select count(*)-9 from t1 use index (ts) where ts <= '2001-01-01 23:59:59';
|
|
|
|
drop table t1;
|
|
|
|
# decimal (not the new 5.0 thing)
|
|
|
|
create table t1 (
|
|
a int primary key,
|
|
s decimal(12),
|
|
t decimal(12, 5),
|
|
u decimal(12) unsigned,
|
|
v decimal(12, 5) unsigned,
|
|
key (s),
|
|
key (t),
|
|
key (u),
|
|
key (v)
|
|
) engine=ndb;
|
|
#
|
|
insert into t1 values
|
|
( 0, -000000000007, -0000061.00003, 000000000061, 0000965.00042),
|
|
( 1, -000000000007, -0000061.00042, 000000000061, 0000965.00003),
|
|
( 2, -071006035767, 4210253.00024, 000000000001, 0000001.84488),
|
|
( 3, 000000007115, 0000000.77607, 000077350625, 0000018.00013),
|
|
( 4, -000000068391, -0346486.00000, 000000005071, 0005334.00002),
|
|
( 5, -521579890459, -1936874.00001, 000000000154, 0000003.00018),
|
|
( 6, -521579890459, -1936874.00018, 000000000154, 0000003.00001),
|
|
( 7, 000000000333, 0000051.39140, 000000907958, 0788643.08374),
|
|
( 8, 000042731229, 0000009.00000, 000000000009, 6428667.00000),
|
|
( 9, -000008159769, 0000918.00004, 000096951421, 7607730.00008);
|
|
#
|
|
select count(*)- 5 from t1 use index (s) where s < -000000000007;
|
|
select count(*)- 7 from t1 use index (s) where s <= -000000000007;
|
|
select count(*)- 2 from t1 use index (s) where s = -000000000007;
|
|
select count(*)- 5 from t1 use index (s) where s >= -000000000007;
|
|
select count(*)- 3 from t1 use index (s) where s > -000000000007;
|
|
#
|
|
select count(*)- 4 from t1 use index (t) where t < -0000061.00003;
|
|
select count(*)- 5 from t1 use index (t) where t <= -0000061.00003;
|
|
select count(*)- 1 from t1 use index (t) where t = -0000061.00003;
|
|
select count(*)- 6 from t1 use index (t) where t >= -0000061.00003;
|
|
select count(*)- 5 from t1 use index (t) where t > -0000061.00003;
|
|
#
|
|
select count(*)- 2 from t1 use index (u) where u < 000000000061;
|
|
select count(*)- 4 from t1 use index (u) where u <= 000000000061;
|
|
select count(*)- 2 from t1 use index (u) where u = 000000000061;
|
|
select count(*)- 8 from t1 use index (u) where u >= 000000000061;
|
|
select count(*)- 6 from t1 use index (u) where u > 000000000061;
|
|
#
|
|
select count(*)- 5 from t1 use index (v) where v < 0000965.00042;
|
|
select count(*)- 6 from t1 use index (v) where v <= 0000965.00042;
|
|
select count(*)- 1 from t1 use index (v) where v = 0000965.00042;
|
|
select count(*)- 5 from t1 use index (v) where v >= 0000965.00042;
|
|
select count(*)- 4 from t1 use index (v) where v > 0000965.00042;
|
|
|
|
drop table t1;
|
|
|
|
# bug#7798
|
|
create table t1(a int primary key, b int not null, index(b));
|
|
insert into t1 values (1,1), (2,2);
|
|
connect (con1,localhost,root,,test);
|
|
connect (con2,localhost,root,,test);
|
|
connection con1;
|
|
set autocommit=0;
|
|
begin;
|
|
select count(*) from t1;
|
|
connection con2;
|
|
ALTER TABLE t1 ADD COLUMN c int;
|
|
connection con1;
|
|
select a from t1 where b = 2;
|
|
show tables;
|
|
drop table t1;
|
|
|
|
# mysqld 5.0.13 crash, no bug#
|
|
create table t1 (a int, c varchar(10),
|
|
primary key using hash (a), index(c)) engine=ndb;
|
|
insert into t1 (a, c) values (1,'aaa'),(3,'bbb');
|
|
select count(*) from t1 where c<'bbb';
|
|
drop table t1;
|
|
|
|
# -- index statistics --
|
|
|
|
set autocommit=1;
|
|
show session variables like 'ndb_index_stat_%';
|
|
|
|
set ndb_index_stat_enable = off;
|
|
show session variables like 'ndb_index_stat_%';
|
|
|
|
create table t1 (a int, b int, c varchar(10) not null,
|
|
primary key using hash (a), index(b,c)) engine=ndb;
|
|
insert into t1 values
|
|
(1,10,'aaa'),(2,10,'bbb'),(3,10,'ccc'),
|
|
(4,20,'aaa'),(5,20,'bbb'),(6,20,'ccc'),
|
|
(7,30,'aaa'),(8,30,'bbb'),(9,30,'ccc');
|
|
select count(*) from t1 where b < 10;
|
|
select count(*) from t1 where b >= 10 and c >= 'bbb';
|
|
select count(*) from t1 where b > 10;
|
|
select count(*) from t1 where b <= 20 and c < 'ccc';
|
|
select count(*) from t1 where b = 20 and c = 'ccc';
|
|
select count(*) from t1 where b > 20;
|
|
select count(*) from t1 where b = 30 and c > 'aaa';
|
|
select count(*) from t1 where b <= 20;
|
|
select count(*) from t1 where b >= 20 and c > 'aaa';
|
|
drop table t1;
|
|
|
|
set ndb_index_stat_enable = on;
|
|
set ndb_index_stat_cache_entries = 0;
|
|
show session variables like 'ndb_index_stat_%';
|
|
|
|
create table t1 (a int, b int, c varchar(10) not null,
|
|
primary key using hash (a), index(b,c)) engine=ndb;
|
|
insert into t1 values
|
|
(1,10,'aaa'),(2,10,'bbb'),(3,10,'ccc'),
|
|
(4,20,'aaa'),(5,20,'bbb'),(6,20,'ccc'),
|
|
(7,30,'aaa'),(8,30,'bbb'),(9,30,'ccc');
|
|
select count(*) from t1 where b < 10;
|
|
select count(*) from t1 where b >= 10 and c >= 'bbb';
|
|
select count(*) from t1 where b > 10;
|
|
select count(*) from t1 where b <= 20 and c < 'ccc';
|
|
select count(*) from t1 where b = 20 and c = 'ccc';
|
|
select count(*) from t1 where b > 20;
|
|
select count(*) from t1 where b = 30 and c > 'aaa';
|
|
select count(*) from t1 where b <= 20;
|
|
select count(*) from t1 where b >= 20 and c > 'aaa';
|
|
drop table t1;
|
|
|
|
set ndb_index_stat_enable = on;
|
|
set ndb_index_stat_cache_entries = 4;
|
|
set ndb_index_stat_update_freq = 2;
|
|
show session variables like 'ndb_index_stat_%';
|
|
|
|
create table t1 (a int, b int, c varchar(10) not null,
|
|
primary key using hash (a), index(b,c)) engine=ndb;
|
|
insert into t1 values
|
|
(1,10,'aaa'),(2,10,'bbb'),(3,10,'ccc'),
|
|
(4,20,'aaa'),(5,20,'bbb'),(6,20,'ccc'),
|
|
(7,30,'aaa'),(8,30,'bbb'),(9,30,'ccc');
|
|
select count(*) from t1 where b < 10;
|
|
select count(*) from t1 where b >= 10 and c >= 'bbb';
|
|
select count(*) from t1 where b > 10;
|
|
select count(*) from t1 where b <= 20 and c < 'ccc';
|
|
select count(*) from t1 where b = 20 and c = 'ccc';
|
|
select count(*) from t1 where b > 20;
|
|
select count(*) from t1 where b = 30 and c > 'aaa';
|
|
select count(*) from t1 where b <= 20;
|
|
select count(*) from t1 where b >= 20 and c > 'aaa';
|
|
drop table t1;
|
|
|
|
set ndb_index_stat_enable = @@global.ndb_index_stat_enable;
|
|
set ndb_index_stat_cache_entries = @@global.ndb_index_stat_cache_entries;
|
|
set ndb_index_stat_update_freq = @@global.ndb_index_stat_update_freq;
|
|
show session variables like 'ndb_index_stat_%';
|
|
|
|
# End of 4.1 tests
|
|
|
|
# bug#24039
|
|
|
|
create table t1 (a int primary key) engine = ndb;
|
|
insert into t1 values (1), (2), (3);
|
|
begin;
|
|
delete from t1 where a > 1;
|
|
rollback;
|
|
select * from t1 order by a;
|
|
begin;
|
|
delete from t1 where a > 1;
|
|
rollback;
|
|
|
|
begin;
|
|
select * from t1 order by a;
|
|
delete from t1 where a > 2;
|
|
select * from t1 order by a;
|
|
delete from t1 where a > 1;
|
|
select * from t1 order by a;
|
|
delete from t1 where a > 0;
|
|
select * from t1 order by a;
|
|
rollback;
|
|
select * from t1 order by a;
|
|
delete from t1;
|
|
drop table t1;
|
|
|
|
# bug#24820 CREATE INDEX ....USING HASH on NDB table creates ordered index, not HASH index
|
|
|
|
--error ER_CANT_CREATE_TABLE
|
|
create table nationaldish (DishID int(10) unsigned NOT NULL AUTO_INCREMENT,
|
|
CountryCode char(3) NOT NULL,
|
|
DishTitle varchar(64) NOT NULL,
|
|
calories smallint(5) unsigned DEFAULT NULL,
|
|
PRIMARY KEY (DishID),
|
|
INDEX i USING HASH (countrycode,calories)
|
|
) ENGINE=ndbcluster;
|
|
|
|
create table nationaldish (DishID int(10) unsigned NOT NULL AUTO_INCREMENT,
|
|
CountryCode char(3) NOT NULL,
|
|
DishTitle varchar(64) NOT NULL,
|
|
calories smallint(5) unsigned DEFAULT NULL,
|
|
PRIMARY KEY (DishID)
|
|
) ENGINE=ndbcluster;
|
|
|
|
--error ER_UNSUPPORTED_EXTENSION
|
|
create index i on nationaldish(countrycode,calories) using hash;
|
|
|
|
drop table nationaldish;
|