888 lines
		
	
	
		
			22 KiB
		
	
	
	
		
			Plaintext
		
	
	
			
		
		
	
	
			888 lines
		
	
	
		
			22 KiB
		
	
	
	
		
			Plaintext
		
	
	
| -- source include/have_ndb.inc
 | |
| 
 | |
| #
 | |
| # Basic test of the ndbcluster plugin 
 | |
| #
 | |
| 
 | |
| #
 | |
| # Show status and variables
 | |
| #
 | |
| --replace_column 2 #
 | |
| --sorted_result
 | |
| SHOW GLOBAL STATUS LIKE 'ndb\_%';
 | |
| --replace_column 2 #
 | |
| --sorted_result
 | |
| # Avoid deprecations warnings from SHOW GLOBAL VARIABLES
 | |
| --disable_warnings
 | |
| SHOW GLOBAL VARIABLES WHERE Variable_name LIKE 'ndb\_%' and 
 | |
|                             Variable_name NOT LIKE 'ndb_dbg\_%';
 | |
| --enable_warnings
 | |
| 
 | |
| #
 | |
| # Create a normal table with primary key
 | |
| #
 | |
| CREATE TABLE t1 (
 | |
|   pk1 INT NOT NULL PRIMARY KEY,
 | |
|   attr1 INT NOT NULL,
 | |
|   attr2 INT,
 | |
|   attr3 VARCHAR(10)
 | |
| ) ENGINE=ndbcluster;
 | |
| 
 | |
| SHOW INDEX FROM t1;  
 | |
| INSERT INTO t1 VALUES (9410,9412, NULL, '9412'), (9411,9413, 17, '9413');
 | |
| SHOW INDEX FROM t1;  
 | |
| SELECT pk1 FROM t1 ORDER BY pk1;
 | |
| SELECT * FROM t1 ORDER BY pk1;
 | |
| SELECT t1.* FROM t1 ORDER BY pk1;
 | |
| 
 | |
| # Update on record by primary key
 | |
| UPDATE t1 SET attr1=1 WHERE pk1=9410;
 | |
| SELECT * FROM t1 ORDER BY pk1;
 | |
| 
 | |
| # Update primary key
 | |
| UPDATE t1 SET pk1=2 WHERE attr1=1;
 | |
| SELECT * FROM t1 ORDER BY pk1;
 | |
| UPDATE t1 SET pk1=pk1 + 1;
 | |
| SELECT * FROM t1 ORDER BY pk1;
 | |
| UPDATE t1 SET pk1=4 WHERE pk1 = 3;
 | |
| SELECT * FROM t1 ORDER BY pk1;
 | |
| 
 | |
| # Delete the record
 | |
| DELETE FROM t1;
 | |
| SELECT * FROM t1;
 | |
| 
 | |
| # Insert more records and update them all at once
 | |
| INSERT INTO t1 VALUES (9410,9412, NULL, '9412'), (9408, 8765, NULL, '8765'),
 | |
| (7,8, NULL, NULL), (8,9, NULL, NULL), (9,10, NULL, NULL), (10,11, NULL, NULL), (11,12, NULL, NULL), (12,13, NULL, NULL), (13,14, NULL, NULL);
 | |
| UPDATE t1 SET attr1 = 9999;
 | |
| SELECT * FROM t1 ORDER BY pk1;
 | |
| 
 | |
| UPDATE t1 SET attr1 = 9998 WHERE pk1 < 1000;
 | |
| SELECT * FROM t1 ORDER BY pk1;
 | |
| 
 | |
| UPDATE t1 SET attr1 = 9997 WHERE attr1 = 9999;
 | |
| SELECT * FROM t1 ORDER BY pk1;
 | |
| 
 | |
| # Delete one record by specifying pk
 | |
| DELETE FROM t1 WHERE pk1 = 9410;
 | |
| SELECT * FROM t1 ORDER BY pk1;
 | |
| 
 | |
| # Delete all from table
 | |
| DELETE FROM t1;
 | |
| SELECT * FROM t1;
 | |
| 
 | |
| # Insert three records with attr1=4 and two with attr1=5
 | |
| # Delete all with attr1=4
 | |
| INSERT INTO t1 values (1, 4, NULL, NULL), (2, 4, NULL, NULL), (3, 5, NULL, NULL), (4, 4, NULL, NULL), (5, 5, NULL, NULL);
 | |
| DELETE FROM t1 WHERE attr1=4;
 | |
| SELECT * FROM t1 order by pk1;
 | |
| DELETE FROM t1;
 | |
| 
 | |
| # Insert two records and delete one
 | |
| INSERT INTO t1 VALUES (9410,9412, NULL, NULL), (9411, 9413, NULL, NULL);
 | |
| DELETE FROM t1 WHERE pk1 = 9410;
 | |
| SELECT * FROM t1;
 | |
| DROP TABLE t1;
 | |
| 
 | |
| #
 | |
| # Create table without primary key
 | |
| # a hidden primary key column is created by handler
 | |
| #
 | |
| CREATE TABLE t1 (id INT, id2 int) engine=ndbcluster;
 | |
| INSERT INTO t1 values(3456, 7890);
 | |
| SELECT * FROM t1;
 | |
| UPDATE t1 SET id=2 WHERE id2=12;
 | |
| SELECT * FROM t1;
 | |
| UPDATE t1 SET id=1234 WHERE id2=7890;
 | |
| SELECT * FROM t1;
 | |
| DELETE FROM t1;
 | |
| 
 | |
| INSERT INTO t1 values(3456, 7890), (3456, 7890), (3456, 7890), (3454, 7890);
 | |
| SELECT * FROM t1 ORDER BY id;
 | |
| DELETE FROM t1 WHERE id = 3456;
 | |
| SELECT * FROM t1 ORDER BY id;
 | |
| 
 | |
| DROP TABLE t1;
 | |
| 
 | |
| # test create with the keyword "engine=NDBCLUSTER"
 | |
| CREATE TABLE t1 (
 | |
|   pk1 INT NOT NULL PRIMARY KEY,
 | |
|   attr1 INT NOT NULL
 | |
| ) ENGINE=NDBCLUSTER;
 | |
| 
 | |
| INSERT INTO t1 values(1, 9999);
 | |
| 
 | |
| DROP TABLE t1;
 | |
| 
 | |
| # test create with the keyword "engine=NDB"
 | |
| CREATE TABLE t1 (
 | |
|   pk1 INT NOT NULL PRIMARY KEY,
 | |
|   attr1 INT NOT NULL
 | |
| ) ENGINE=NDB;
 | |
| 
 | |
| INSERT INTO t1 values(1, 9999);
 | |
| 
 | |
| DROP TABLE t1;
 | |
| 
 | |
| 
 | |
| #
 | |
| # A more extensive test with a lot more records
 | |
| #
 | |
| 
 | |
| CREATE TABLE t2 (
 | |
|   a bigint unsigned NOT NULL PRIMARY KEY,
 | |
|   b int unsigned not null,
 | |
|   c int unsigned
 | |
| ) engine=ndbcluster;
 | |
| 
 | |
| CREATE TABLE t3 (
 | |
|   a bigint unsigned NOT NULL,
 | |
|   b bigint unsigned not null,
 | |
|   c bigint unsigned,
 | |
|   PRIMARY KEY(a)
 | |
| ) engine=ndbcluster;
 | |
| 
 | |
| CREATE TABLE t4 (
 | |
|   a bigint unsigned NOT NULL,
 | |
|   b bigint unsigned not null,
 | |
|   c bigint unsigned NOT NULL,
 | |
|   d int unsigned,
 | |
|   PRIMARY KEY(a, b, c)
 | |
| ) engine=ndbcluster;
 | |
| 
 | |
| 
 | |
| #
 | |
| # insert more records into tables
 | |
| #
 | |
| let $1=1000;
 | |
| disable_query_log;
 | |
| while ($1)
 | |
| {
 | |
|  eval insert into t2 values($1, $1+9, 5);
 | |
|  eval insert into t3 values($1, $1+9, 5);
 | |
|  eval insert into t4 values($1, $1+9, 5, $1+26000);
 | |
|  dec $1;
 | |
| }
 | |
| enable_query_log;
 | |
| 
 | |
| 
 | |
| #
 | |
| # delete every other record in the tables
 | |
| #
 | |
| let $1=1000;
 | |
| disable_query_log;
 | |
| while ($1)
 | |
| {
 | |
|  eval delete from t2 where a=$1;
 | |
|  eval delete from t3 where a=$1;
 | |
|  eval delete from t4 where a=$1 and b=$1+9 and c=5;
 | |
|  dec $1;
 | |
|  dec $1;
 | |
| }
 | |
| enable_query_log;
 | |
| 
 | |
| 
 | |
| select * from t2 where a = 7 order by b;
 | |
| select * from t2 where a = 7 order by a;
 | |
| select * from t2 where a = 7 order by 2;
 | |
| select * from t2 where a = 7 order by c;
 | |
| 
 | |
| select * from t2 where a = 7 and b = 16 order by b;
 | |
| select * from t2 where a = 7 and b = 16 order by a;
 | |
| select * from t2 where a = 7 and b = 17 order by a;
 | |
| select * from t2 where a = 7 and b != 16 order by b;
 | |
| 
 | |
| select * from t2 where a = 7 and b = 16 and c = 5 order by b;
 | |
| select * from t2 where a = 7 and b = 16 and c = 5 order by a;
 | |
| select * from t2 where a = 7 and b = 16 and c = 6 order by a;
 | |
| select * from t2 where a = 7 and b != 16 and c = 5 order by b;
 | |
| 
 | |
| select * from t3 where a = 7 order by b;
 | |
| select * from t3 where a = 7 order by a;
 | |
| select * from t3 where a = 7 order by 2;
 | |
| select * from t3 where a = 7 order by c;
 | |
| 
 | |
| select * from t3 where a = 7 and b = 16 order by b;
 | |
| select * from t3 where a = 7 and b = 16 order by a;
 | |
| select * from t3 where a = 7 and b = 17 order by a;
 | |
| select * from t3 where a = 7 and b != 16 order by b;
 | |
| 
 | |
| select * from t4 where a = 7 order by b;
 | |
| select * from t4 where a = 7 order by a;
 | |
| select * from t4 where a = 7 order by 2;
 | |
| select * from t4 where a = 7 order by c;
 | |
| 
 | |
| select * from t4 where a = 7 and b = 16 order by b;
 | |
| select * from t4 where a = 7 and b = 16 order by a;
 | |
| select * from t4 where a = 7 and b = 17 order by a;
 | |
| select * from t4 where a = 7 and b != 16 order by b;
 | |
| 
 | |
| #
 | |
| # update records
 | |
| #
 | |
| let $1=1000;
 | |
| disable_query_log;
 | |
| while ($1)
 | |
| {
 | |
|  eval update t2 set c=$1 where a=$1;
 | |
|  eval update t3 set c=7 where a=$1 and b=$1+9 and c=5;
 | |
|  eval update t4 set d=$1+21987 where a=$1 and b=$1+9 and c=5;
 | |
|  dec $1;
 | |
|  dec $1;
 | |
| }
 | |
| enable_query_log;
 | |
| 
 | |
| delete from t2 where a > 5;
 | |
| select x1.a, x1.b from t2 x1, t2 x2 where x1.b = x2.b order by x1.a;
 | |
| select a, b FROM t2 outer_table where
 | |
| a = (select a from t2 where b = outer_table.b ) order by a;
 | |
| 
 | |
| 
 | |
| delete from t2;
 | |
| delete from t3;
 | |
| delete from t4;
 | |
| 
 | |
| drop table t2;
 | |
| drop table t3;
 | |
| drop table t4;
 | |
| 
 | |
| #
 | |
| # Test delete and update from table with 3 keys
 | |
| #
 | |
| 
 | |
| CREATE TABLE t5 (
 | |
|   a bigint unsigned NOT NULL,
 | |
|   b bigint unsigned not null,
 | |
|   c bigint unsigned NOT NULL,
 | |
|   d int unsigned,
 | |
|   PRIMARY KEY(a, b, c)
 | |
| ) engine=ndbcluster;
 | |
| 
 | |
| insert into t5 values(10, 19, 5, 26010);
 | |
| 
 | |
| delete from t5 where a=10 and b=19 and c=5;
 | |
| 
 | |
| select * from t5;
 | |
| 
 | |
| insert into t5 values(10, 19, 5, 26010);
 | |
| 
 | |
| update t5 set d=21997 where a=10 and b=19 and c=5;
 | |
| 
 | |
| select * from t5;
 | |
| 
 | |
| delete from t5;
 | |
| 
 | |
| drop table t5;
 | |
| 
 | |
| #
 | |
| # Test using table with a char(255) column first in table
 | |
| #
 | |
| 
 | |
| CREATE TABLE t6 (
 | |
|   adress char(255),
 | |
|   a int NOT NULL PRIMARY KEY,
 | |
|   b int
 | |
| ) engine = NDB;
 | |
| 
 | |
| insert into t6 values
 | |
|  ("Nice road 3456", 1, 23),
 | |
|  ("Street Road 78", 3, 92),
 | |
|  ("Road street 89C", 5, 71),
 | |
|  (NULL, 7, NULL);
 | |
| select * from t6 order by a;
 | |
| select a, b from t6 order by a;
 | |
| 
 | |
| update t6 set adress="End of road 09" where a=3;
 | |
| update t6 set b=181, adress="Street 76" where a=7;
 | |
| select * from t6 order by a;
 | |
| select * from t6 where a=1;
 | |
| delete from t6 where a=1;
 | |
| select * from t6 order by a;
 | |
| delete from t6 where b=71;
 | |
| select * from t6 order by a;
 | |
| 
 | |
| drop table t6;
 | |
| 
 | |
| #
 | |
| # Test using table with a char(255) column first in table and a 
 | |
| # primary key consisting of two columns
 | |
| #
 | |
| 
 | |
| CREATE TABLE t7 (
 | |
|   adress char(255),
 | |
|   a int NOT NULL,
 | |
|   b int,
 | |
|   c int NOT NULL,
 | |
|   PRIMARY KEY(a, c)	
 | |
| ) engine = NDB;
 | |
| 
 | |
| insert into t7 values
 | |
|  ("Highway 3456", 1, 23, 2),
 | |
|  ("Street Road 78", 3, 92, 3),
 | |
|  ("Main street 89C", 5, 71, 4),
 | |
|  (NULL, 8, NULL, 12);
 | |
| select * from t7 order by a;
 | |
| select a, b from t7 order by a;
 | |
| 
 | |
| update t7 set adress="End of road 09" where a=3;
 | |
| update t7 set adress="Gatuvägen 90C" where a=5 and c=4;
 | |
| update t7 set adress="No adress" where adress is NULL;
 | |
| select * from t7 order by a;
 | |
| select * from t7 where a=1 and c=2;
 | |
| delete from t7 where a=1;
 | |
| delete from t7 where a=3 and c=3;
 | |
| delete from t7 where a=5 and c=4;
 | |
| select * from t7;
 | |
| delete from t7 where b=23;
 | |
| select * from t7;
 | |
| 
 | |
| drop table t7;
 | |
| 
 | |
| #
 | |
| # Test multiple databases in one statement
 | |
| #
 | |
| 
 | |
| CREATE TABLE t1 (
 | |
|   pk1 INT NOT NULL PRIMARY KEY,
 | |
|   attr1 INT NOT NULL,
 | |
|   attr2 INT,
 | |
|   attr3 VARCHAR(10)
 | |
| ) ENGINE=ndbcluster;
 | |
| 
 | |
| INSERT INTO t1 VALUES (9410,9412, NULL, '9412'), (9411,9413, 17, '9413');
 | |
| 
 | |
| create database mysqltest;
 | |
| use mysqltest;
 | |
| 
 | |
| CREATE TABLE t2 (
 | |
|   a bigint unsigned NOT NULL PRIMARY KEY,
 | |
|   b int unsigned not null,
 | |
|   c int unsigned
 | |
| ) engine=ndbcluster;
 | |
| 
 | |
| insert into t2 select pk1,attr1,attr2 from test.t1;
 | |
| select * from t2 order by a;
 | |
| select b from test.t1, t2 where c = test.t1.attr2;
 | |
| select b,test.t1.attr1 from test.t1, t2 where test.t1.pk1 < a;
 | |
|  
 | |
| drop table test.t1, t2;
 | |
| drop database mysqltest;
 | |
| 
 | |
| #
 | |
| # BUG#6031 - DROP DATABASE doesn't drop database on first try
 | |
| #
 | |
| 
 | |
| --disable_warnings
 | |
| drop database if exists ndbtest1;
 | |
| --enable_warnings
 | |
| 
 | |
| create database ndbtest1;
 | |
| use ndbtest1;
 | |
| create table t1(id int) engine=ndbcluster;
 | |
| drop database ndbtest1;
 | |
| --error 1008
 | |
| drop database ndbtest1;
 | |
| 
 | |
| #
 | |
| # test support of char(0)
 | |
| #
 | |
| 
 | |
| use test;
 | |
| create table t1 (a int primary key, b char(0));
 | |
| insert into t1 values (1,"");
 | |
| insert into t1 values (2,NULL);
 | |
| select * from t1 order by a;
 | |
| select * from t1 order by b;
 | |
| select * from t1 where b IS NULL;
 | |
| select * from t1 where b IS NOT NULL;
 | |
| drop table t1;
 | |
| 
 | |
| #
 | |
| # test the limit of no of attributes in one table
 | |
| #  - use while loop to build dynamic sql string
 | |
| #
 | |
| let $i=511; # The current max number of attributes
 | |
| let $separator=;
 | |
| let $sql=create table t1 (;
 | |
| while ($i)
 | |
| {
 | |
|   let $sql=$sql$separator c$i int;
 | |
|   let $separator=,;
 | |
|   dec $i;
 | |
| }
 | |
| let $sql=$sql, c512 varchar(10000);
 | |
| let $sql=$sql, primary key using hash(c1)) engine=ndb;
 | |
| let $sql=$sql charset=latin1;
 | |
| let $sql=$sql partition by key(c1);
 | |
| #             ^^^^^^^^^^^^^^^^^^^^
 | |
| #             also tests bug#17179, more than 31
 | |
| #             attributes in a partitioned table
 | |
| 
 | |
| eval $sql; # eval the sql and create the table
 | |
| 
 | |
| set @v10 = '0123456789';
 | |
| set @v100 = concat(@v10,@v10,@v10,@v10,@v10,@v10,@v10,@v10,@v10,@v10);
 | |
| set @v1000 =concat(@v100,@v100,@v100,@v100,@v100,@v100,@v100,@v100,@v100,@v100);
 | |
| set @v10000 = concat(@v1000,@v1000,@v1000,@v1000,@v1000,@v1000,@v1000,@v1000,@v1000,@v1000);
 | |
| set @v13000 = concat(@v10000, @v1000,@v1000,@v1000);
 | |
| 
 | |
| insert into t1 (c1,c512) values (1,@v10000), (2,@v10000), (3,@v10000);
 | |
| select c1, length(c512) from t1 order by 1;
 | |
| delete from t1;
 | |
| drop table t1;
 | |
| # Bug #21863798 CREATING TABLE WITH MAX NUMBER OF DYNAMIC ATTRIBUTES CAUSES NODE CRASH
 | |
| let $i=511; # The current max number of attributes
 | |
| let $separator=;
 | |
| let $sql=create table t1 (;
 | |
| while ($i)
 | |
| {
 | |
|   let $sql=$sql$separator c$i int column_format dynamic;
 | |
|   let $separator=,;
 | |
|   dec $i;
 | |
| }
 | |
| let $sql=$sql, c512 varchar(10000);
 | |
| let $sql=$sql, primary key using hash(c1)) engine=ndb;
 | |
| let $sql=$sql charset=latin1;
 | |
| let $sql=$sql partition by key(c1);
 | |
| 
 | |
| eval $sql; # eval the sql and create the table
 | |
| 
 | |
| set @v10 = '0123456789';
 | |
| set @v100 = concat(@v10,@v10,@v10,@v10,@v10,@v10,@v10,@v10,@v10,@v10);
 | |
| set @v1000 = concat(@v100,@v100,@v100,@v100,@v100,@v100,@v100,@v100,@v100,@v100);
 | |
| set @v10000 = concat(@v1000,@v1000,@v1000,@v1000,@v1000,@v1000,@v1000,@v1000,@v1000,@v1000);
 | |
| 
 | |
| set @v13000 = concat(@v10000, @v1000,@v1000,@v1000);
 | |
| 
 | |
| insert into t1 (c1,c512) values (1,@v10000), (2,@v10000), (3,@v10000);
 | |
| select c1, length(c512) from t1 order by 1;
 | |
| delete from t1;
 | |
| drop table t1;
 | |
| 
 | |
| create table t1 (
 | |
|   a int primary key,
 | |
|   b varchar(13000)
 | |
| ) engine = ndb charset=latin1;
 | |
| insert into t1 values (1,@v13000), (2,@v13000);
 | |
| select length(b) from t1 order by 1;
 | |
| drop table t1;
 | |
| 
 | |
| let $i=50;
 | |
| let $separator=;
 | |
| let $sql=create table t1 (;
 | |
| while ($i)
 | |
| {
 | |
|   let $sql=$sql$separator c$i char(255) column_format fixed;
 | |
|   let $separator=,;
 | |
|   dec $i;
 | |
| }
 | |
| let $sql=$sql, primary key using hash(c1)) engine=ndb;
 | |
| let $sql=$sql charset=latin1;
 | |
| 
 | |
| --error ER_CANT_CREATE_TABLE
 | |
| eval $sql; # eval the sql and create the table
 | |
| show warnings;
 | |
| 
 | |
| #
 | |
| # test bug#53354 - crash when creating partitioned table with multiple columns in the partition key
 | |
| #
 | |
| 
 | |
| --error ER_SAME_NAME_PARTITION_FIELD
 | |
| create table `t1` (`a` int, b int, primary key (a,b)) engine=ndb partition by key(`a`,`b`,`a`);
 | |
| 
 | |
| #
 | |
| # test max size of attribute name and truncation
 | |
| #
 | |
| 
 | |
| create table t1 (
 | |
| a1234567890123456789012345678901234567890 int primary key,
 | |
| a12345678901234567890123456789a1234567890 int,
 | |
| index(a12345678901234567890123456789a1234567890)
 | |
| ) engine=ndb
 | |
|   comment="NDB_TABLE=PARTITION_BALANCE=FOR_RP_BY_LDM";
 | |
| show tables;
 | |
| insert into t1 values (1,1),(2,1),(3,1),(4,1),(5,2),(6,1),(7,1);
 | |
| --replace_column 10 # 11 #
 | |
| explain select * from t1 where a12345678901234567890123456789a1234567890=2;
 | |
| select * from t1 where a12345678901234567890123456789a1234567890=2;
 | |
| drop table t1;
 | |
| 
 | |
| #
 | |
| # test fragment creation
 | |
| #
 | |
| # first a table with _many_ fragments per node group
 | |
| # then a table with just one fragment per node group
 | |
| #
 | |
| create table t1
 | |
|   (a bigint, b bigint, c bigint, d bigint, 
 | |
|    primary key (a,b,c,d)) 
 | |
|   engine=ndb
 | |
|   max_rows=800000000;
 | |
| insert into t1 values
 | |
|   (1,2,3,4),(2,3,4,5),(3,4,5,6),
 | |
|   (3,2,3,4),(1,3,4,5),(2,4,5,6),
 | |
|   (1,2,3,5),(2,3,4,8),(3,4,5,9),
 | |
|   (3,2,3,5),(1,3,4,8),(2,4,5,9),
 | |
|   (1,2,3,6),(2,3,4,6),(3,4,5,7),
 | |
|   (3,2,3,6),(1,3,4,6),(2,4,5,7),
 | |
|   (1,2,3,7),(2,3,4,7),(3,4,5,8),
 | |
|   (3,2,3,7),(1,3,4,7),(2,4,5,8),
 | |
|   (1,3,3,4),(2,4,4,5),(3,5,5,6),
 | |
|   (3,3,3,4),(1,4,4,5),(2,5,5,6),
 | |
|   (1,3,3,5),(2,4,4,8),(3,5,5,9),
 | |
|   (3,3,3,5),(1,4,4,8),(2,5,5,9),
 | |
|   (1,3,3,6),(2,4,4,6),(3,5,5,7),
 | |
|   (3,3,3,6),(1,4,4,6),(2,5,5,7),
 | |
|   (1,3,3,7),(2,4,4,7),(3,5,5,8),
 | |
|   (3,3,3,7),(1,4,4,7),(2,5,5,8);
 | |
| select count(*) from t1;
 | |
| select count(*) into @cnt_big
 | |
| from information_schema.partitions
 | |
| where table_schema = 'test' and table_name = 't1';
 | |
| drop table t1;
 | |
| 
 | |
| create table t1
 | |
|   (a bigint, b bigint, c bigint, d bigint, 
 | |
|    primary key (a,b,c,d))
 | |
|   engine=ndb
 | |
|   max_rows=1;
 | |
| insert into t1 values
 | |
|   (1,2,3,4),(2,3,4,5),(3,4,5,6),
 | |
|   (3,2,3,4),(1,3,4,5),(2,4,5,6),
 | |
|   (1,2,3,5),(2,3,4,8),(3,4,5,9),
 | |
|   (3,2,3,5),(1,3,4,8),(2,4,5,9),
 | |
|   (1,2,3,6),(2,3,4,6),(3,4,5,7),
 | |
|   (3,2,3,6),(1,3,4,6),(2,4,5,7),
 | |
|   (1,2,3,7),(2,3,4,7),(3,4,5,8),
 | |
|   (3,2,3,7),(1,3,4,7),(2,4,5,8),
 | |
|   (1,3,3,4),(2,4,4,5),(3,5,5,6),
 | |
|   (3,3,3,4),(1,4,4,5),(2,5,5,6),
 | |
|   (1,3,3,5),(2,4,4,8),(3,5,5,9),
 | |
|   (3,3,3,5),(1,4,4,8),(2,5,5,9),
 | |
|   (1,3,3,6),(2,4,4,6),(3,5,5,7),
 | |
|   (3,3,3,6),(1,4,4,6),(2,5,5,7),
 | |
|   (1,3,3,7),(2,4,4,7),(3,5,5,8),
 | |
|   (3,3,3,7),(1,4,4,7),(2,5,5,8);
 | |
| select count(*) into @cnt_small
 | |
| from information_schema.partitions
 | |
| where table_schema = 'test' and table_name = 't1';
 | |
| drop table t1;
 | |
| 
 | |
| # Check
 | |
| select @cnt_big > @cnt_small;
 | |
| 
 | |
| #
 | |
| # Test auto_increment
 | |
| #
 | |
| 
 | |
| connect (con1,localhost,root,,test);
 | |
| connect (con2,localhost,root,,test);
 | |
| 
 | |
| create table t1
 | |
| 	(counter int(64) NOT NULL auto_increment,
 | |
| 	 datavalue char(40) default 'XXXX',
 | |
| 	 primary key (counter)
 | |
| 	) ENGINE=ndbcluster;
 | |
| 
 | |
| connection con1;
 | |
| insert into t1 (datavalue) values ('newval');
 | |
| insert into t1 (datavalue) values ('newval');
 | |
| select * from t1 order by counter;
 | |
| insert into t1 (datavalue) select datavalue from t1 where counter < 100;
 | |
| insert into t1 (datavalue) select datavalue from t1 where counter < 100;
 | |
| select * from t1 order by counter;
 | |
| connection con2;
 | |
| insert into t1 (datavalue) select datavalue from t1 where counter < 100;
 | |
| insert into t1 (datavalue) select datavalue from t1 where counter < 100;
 | |
| select * from t1 order by counter;
 | |
| 
 | |
| drop table t1;
 | |
| 
 | |
| #
 | |
| # bug#27437
 | |
| connection con1;
 | |
| create table t1 (a int primary key auto_increment) engine = ndb;
 | |
| insert into t1() values (),(),(),(),(),(),(),(),(),(),(),();
 | |
| connection con2;
 | |
| insert into t1(a) values (20),(28);
 | |
| connection con1;
 | |
| insert into t1() values (),(),(),(),(),(),(),(),(),(),(),();
 | |
| connection con2;
 | |
| insert into t1() values (21), (22);
 | |
| connection con1;
 | |
| 
 | |
| drop table t1;
 | |
| 
 | |
| #
 | |
| # BUG#14514 Creating table with packed key fails silently
 | |
| #
 | |
| 
 | |
| CREATE TABLE t1 ( b INT ) PACK_KEYS = 0 ENGINE = ndb;
 | |
| select * from t1;
 | |
| drop table t1;
 | |
| 
 | |
| #
 | |
| # Bug #17249 delete statement with join where clause fails 
 | |
| # when table do not have pk
 | |
| 	#
 | |
| 
 | |
| create table t1 (a int) engine=ndb;
 | |
| create table t2 (a int) engine=ndb;
 | |
| insert into t1 values (1);
 | |
| insert into t2 values (1);
 | |
| delete t1.* from t1, t2 where t1.a = t2.a;
 | |
| select * from t1;
 | |
| select * from t2;
 | |
| drop table t1;
 | |
| drop table t2;
 | |
| 
 | |
| #
 | |
| # Bug #17257 update fails for inner joins if tables 
 | |
| # do not have Primary Key
 | |
| #
 | |
| 
 | |
| CREATE TABLE t1 (
 | |
|   i   INT,
 | |
|   j   INT,
 | |
|   x   INT,
 | |
|   y   INT,
 | |
|   z   INT
 | |
| ) engine=ndb;
 | |
| 
 | |
| CREATE TABLE t2 (
 | |
|   i   INT,
 | |
|   k   INT,
 | |
|   x   INT,
 | |
|   y   INT,
 | |
|   z   INT
 | |
| ) engine=ndb;
 | |
| 
 | |
| CREATE TABLE t3 (
 | |
|   j   INT,
 | |
|   k   INT,
 | |
|   x   INT,
 | |
|   y   INT,
 | |
|   z   INT
 | |
| ) engine=ndb;
 | |
| 
 | |
| INSERT INTO t1 VALUES ( 1, 2,13,14,15);
 | |
| INSERT INTO t2 VALUES ( 1, 3,23,24,25);
 | |
| INSERT INTO t3 VALUES ( 2, 3, 1,34,35), ( 2, 3, 1,34,36);
 | |
| 
 | |
| UPDATE      t1 AS a
 | |
| INNER JOIN  t2 AS b
 | |
|               ON a.i = b.i
 | |
| INNER JOIN  t3 AS c
 | |
|               ON a.j = c.j  AND  b.k = c.k
 | |
| SET         a.x = b.x,
 | |
|             a.y = b.y,
 | |
|             a.z = (
 | |
|               SELECT  sum(z)
 | |
|               FROM    t3
 | |
|               WHERE   y = 34
 | |
|             )
 | |
| WHERE       b.x = 23;
 | |
| select * from t1;
 | |
| drop table t1;
 | |
| drop table t2;
 | |
| drop table t3;
 | |
| 
 | |
| #
 | |
| # Test long table name
 | |
| #
 | |
| create table atablewithareallylongandirritatingname (a int);
 | |
| insert into atablewithareallylongandirritatingname values (2);
 | |
| select * from atablewithareallylongandirritatingname;
 | |
| drop table atablewithareallylongandirritatingname;
 | |
| 
 | |
| #
 | |
| # Bug#15682
 | |
| #
 | |
| create table t1 (f1 varchar(50), f2 text,f3 int, primary key(f1)) engine=NDB;
 | |
| insert into t1 (f1,f2,f3)VALUES("111111","aaaaaa",1);
 | |
| insert into t1 (f1,f2,f3)VALUES("222222","bbbbbb",2);
 | |
| select * from t1 order by f1;
 | |
| select * from t1 order by f2;
 | |
| select * from t1 order by f3;
 | |
| drop table t1;
 | |
| 
 | |
| #
 | |
| # Bug #25746 - VARCHAR UTF8 PK issue
 | |
| # - prior to bugfix 4209, illegal length parameter would be
 | |
| # returned in SELECT *
 | |
| 
 | |
| CREATE TABLE t1 (
 | |
| a VARBINARY(40) NOT NULL,
 | |
| b VARCHAR (256) CHARACTER SET UTF8 NOT NULL,
 | |
| c VARCHAR(256) CHARACTER SET UTF8 NOT NULL,
 | |
| PRIMARY KEY (b,c))  ENGINE=ndbcluster;
 | |
| INSERT INTO t1 VALUES
 | |
| ("a","ab","abc"),("b","abc","abcd"),("c","abc","ab"),("d","ab","ab"),("e","abc","abc");
 | |
| SELECT * FROM t1 ORDER BY a;
 | |
| DROP TABLE t1;
 | |
| 
 | |
| # delete
 | |
| create table t1 (a int not null primary key, b int not null) engine=ndb;
 | |
| create table t2 (a int not null primary key, b int not null) engine=ndb;
 | |
| insert into t1 values (1,10), (2,20), (3,30);
 | |
| insert into t2 values (1,10), (2,20), (3,30);
 | |
| select * from t1 order by a;
 | |
| delete from t1 where a > 0 order by a desc limit 1;
 | |
| select * from t1 order by a;
 | |
| delete from t1,t2 using t1,t2 where t1.a = t2.a;
 | |
| select * from t2 order by a;
 | |
| drop table t1,t2;
 | |
| 
 | |
| # insert ignore
 | |
| create table t1 (a int not null primary key, b int not null) engine=ndb;
 | |
| insert into t1 values (1,10), (2,20), (3,30);
 | |
| --error ER_DUP_ENTRY
 | |
| insert into t1 set a=1, b=100;
 | |
| insert ignore into t1 set a=1, b=100;
 | |
| select * from t1 order by a;
 | |
| insert into t1 set a=1, b=1000 on duplicate key update b=b+1;
 | |
| select * from t1 order by a;
 | |
| drop table t1;
 | |
| 
 | |
| # update
 | |
| create table t1 (a int not null primary key, b int not null) engine=ndb;
 | |
| create table t2 (c int not null primary key, d int not null) engine=ndb;
 | |
| insert into t1 values (1,10), (2,10), (3,30), (4, 30);
 | |
| insert into t2 values (1,10), (2,10), (3,30), (4, 30);
 | |
| --error ER_DUP_ENTRY
 | |
| update t1 set a = 1 where a = 3;
 | |
| select * from t1 order by a;
 | |
| update t1 set b = 1 where a > 1 order by a desc limit 1;
 | |
| select * from t1 order by a;
 | |
| --error ER_DUP_ENTRY
 | |
| update t1,t2 set a = 1, c = 1 where a = 3 and c = 3;
 | |
| select * from t1 order by a;
 | |
| update ignore t1,t2 set a = 1, c = 1 where a = 3 and c = 3;
 | |
| select * from t1 order by a;
 | |
| drop table t1,t2;
 | |
| 
 | |
| #
 | |
| # Bug#31635
 | |
| #
 | |
| create table t1 (a varchar(100) primary key, b varchar(100)) engine = NDB;
 | |
| insert into t1 values
 | |
|   ('a', 'a'),('b','b'),('c', 'c'),('aa', 'aa'),('bb', 'bb'),('cc', 'cc');
 | |
| replace into t1 values ('a', '-a');
 | |
| replace into t1 values ('b', '-b');
 | |
| replace into t1 values ('c', '-c');
 | |
| 
 | |
| replace into t1 values ('aa', '-aa');
 | |
| replace into t1 values ('bb', '-bb');
 | |
| replace into t1 values ('cc', '-cc');
 | |
| 
 | |
| replace into t1 values ('aaa', '-aaa');
 | |
| replace into t1 values ('bbb', '-bbb');
 | |
| replace into t1 values ('ccc', '-ccc');
 | |
| select * from t1 order by 1,2;
 | |
| drop table t1;
 | |
| 
 | |
| #
 | |
| # Bug #18483 Cannot create table with FK constraint
 | |
| # ndb does not support foreign key constraint, it is silently ignored
 | |
| # in line with other storage engines
 | |
| #
 | |
| CREATE TABLE t1 (a VARCHAR(255) NOT NULL,
 | |
|                  CONSTRAINT pk_a PRIMARY KEY (a))engine=ndb;
 | |
| CREATE TABLE t2(a VARCHAR(255) NOT NULL,
 | |
|                 b VARCHAR(255) NOT NULL,
 | |
|                 c VARCHAR(255) NOT NULL,
 | |
|                 CONSTRAINT pk_b_c_id PRIMARY KEY (b,c),
 | |
|                 CONSTRAINT fk_a FOREIGN KEY(a) REFERENCES t1(a))engine=ndb;
 | |
| # ndb supports FK now (7.3) so drop in right order
 | |
| drop table t2, t1;
 | |
| 
 | |
| # bug#24301
 | |
| create table t1 (a int not null primary key, b int) engine=ndb;
 | |
| insert into t1 values(1,1),(2,2),(3,3);
 | |
| create table t2 like t1;
 | |
| insert into t2 select * from t1;
 | |
| select * from t1 order by a;
 | |
| select * from t2 order by a;
 | |
| drop table t1, t2;
 | |
| 
 | |
| # create table if not exists
 | |
| --disable_warnings
 | |
| create table t1 (a int not null primary key, b int not null default 0, c varchar(254)) engine=ndb;
 | |
| create table if not exists t1 (a int not null primary key, b int not null default 0, c varchar(254)) engine=ndb;
 | |
| --enable_warnings
 | |
| 
 | |
| # create like
 | |
| create table t2 like t1;
 | |
| 
 | |
| # multi rename
 | |
| rename table t1 to t10, t2 to t20;
 | |
| drop table t10,t20;
 | |
| 
 | |
| --echo #
 | |
| --echo # bug #39872 - explain causes segv
 | |
| --echo # (ndb_index_stat_enable=1 must be set to trigger bug)
 | |
| --echo # index stats v4: do not set, the v2 setting was local
 | |
| --echo #
 | |
| # set ndb_index_stat_enable=1;
 | |
| CREATE TABLE `t1` (
 | |
|   `id` int(11) NOT NULL AUTO_INCREMENT,
 | |
|   PRIMARY KEY (`id`)
 | |
| ) ENGINE=ndbcluster DEFAULT CHARSET=utf8
 | |
|   comment="NDB_TABLE=PARTITION_BALANCE=FOR_RP_BY_LDM";
 | |
| CREATE TABLE `t2` (
 | |
|   `id` int(11) NOT NULL,
 | |
|   `obj_id` int(11) DEFAULT NULL,
 | |
|   UNIQUE KEY `id` (`id`),
 | |
|   KEY `obj_id` (`obj_id`)
 | |
| ) ENGINE=ndbcluster DEFAULT CHARSET=utf8
 | |
|   comment="NDB_TABLE=PARTITION_BALANCE=FOR_RP_BY_LDM";
 | |
| --echo # here we used to segv
 | |
| --replace_column 10 # 11 #
 | |
| explain SELECT t1.id FROM t1 INNER JOIN t2 ON t1.id = t2.id WHERE t2.obj_id=1;
 | |
| drop table t1, t2;
 | |
| 
 | |
| --echo #
 | |
| --echo # Bug #47054 Cluster only deletes first matched row in delete with left join
 | |
| --echo #
 | |
| 
 | |
| CREATE TABLE child
 | |
| ( id INT AUTO_INCREMENT PRIMARY KEY
 | |
| , parent_id INT
 | |
| ) ENGINE=ndb;
 | |
| 
 | |
| CREATE TABLE parent 
 | |
| ( id INT AUTO_INCREMENT PRIMARY KEY
 | |
| ) ENGINE=ndb;
 | |
| 
 | |
| INSERT INTO parent VALUES (NULL),(NULL),(NULL);
 | |
| 
 | |
| INSERT INTO child VALUES (NULL, 1),(NULL,2),(NULL,3),(NULL,4),(NULL,5);
 | |
| 
 | |
| SELECT * FROM child ORDER BY id;
 | |
| 
 | |
| SELECT * 
 | |
| FROM child AS c 
 | |
|   LEFT JOIN parent AS p ON c.parent_id = p.id 
 | |
| WHERE p.id IS NULL AND c.id < 100  ORDER BY c.id;
 | |
| 
 | |
| DELETE c.* 
 | |
| FROM child AS c 
 | |
|   LEFT JOIN parent AS p ON c.parent_id = p.id 
 | |
| WHERE p.id IS NULL AND c.id < 100;
 | |
| 
 | |
| SELECT * FROM child ORDER BY id;
 | |
| 
 | |
| DROP TABLE child, parent;
 | |
| 
 | |
| #
 | |
| # bug#59756
 | |
| #
 | |
| --error ER_CANT_CREATE_TABLE
 | |
| CREATE TABLE t1 (a INT PRIMARY KEY, b TEXT)
 | |
| ENGINE=ndb PARTITION BY KEY(a) PARTITIONS 144;
 | |
| show warnings;
 | |
| CREATE TABLE t1 (a INT PRIMARY KEY, b TEXT)
 | |
| ENGINE=ndb;
 | |
| show warnings;
 | |
| drop table t1;
 |