2004-05-05 16:04:23 +02:00
|
|
|
DROP TABLE IF EXISTS t1;
|
2004-12-06 14:51:10 +01:00
|
|
|
drop database if exists mysqltest;
|
2004-05-05 16:04:23 +02:00
|
|
|
CREATE TABLE t1 (
|
|
|
|
a INT NOT NULL,
|
|
|
|
b INT NOT NULL
|
|
|
|
) ENGINE=ndbcluster;
|
|
|
|
INSERT INTO t1 VALUES (9410,9412);
|
|
|
|
ALTER TABLE t1 ADD COLUMN c int not null;
|
|
|
|
SELECT * FROM t1;
|
|
|
|
a b c
|
|
|
|
9410 9412 0
|
|
|
|
DROP TABLE t1;
|
2004-12-06 14:51:10 +01:00
|
|
|
CREATE DATABASE mysqltest;
|
|
|
|
USE mysqltest;
|
|
|
|
CREATE TABLE t1 (
|
|
|
|
a INT NOT NULL,
|
|
|
|
b INT NOT NULL
|
|
|
|
) ENGINE=ndbcluster;
|
|
|
|
RENAME TABLE t1 TO test.t1;
|
|
|
|
SHOW TABLES;
|
|
|
|
Tables_in_mysqltest
|
|
|
|
DROP DATABASE mysqltest;
|
|
|
|
USE test;
|
|
|
|
SHOW TABLES;
|
|
|
|
Tables_in_test
|
|
|
|
t1
|
|
|
|
DROP TABLE t1;
|
2004-05-05 16:04:23 +02:00
|
|
|
create table t1 (
|
|
|
|
col1 int not null auto_increment primary key,
|
|
|
|
col2 varchar(30) not null,
|
|
|
|
col3 varchar (20) not null,
|
|
|
|
col4 varchar(4) not null,
|
|
|
|
col5 enum('PENDING', 'ACTIVE', 'DISABLED') not null,
|
2004-08-10 14:38:24 +02:00
|
|
|
col6 int not null, to_be_deleted int) ENGINE=ndbcluster;
|
2004-08-12 10:15:53 +02:00
|
|
|
show table status;
|
|
|
|
Name Engine Version Row_format Rows Avg_row_length Data_length Max_data_length Index_length Data_free Auto_increment Create_time Update_time Check_time Collation Checksum Create_options Comment
|
moved all ndb thread specific data into new placeholder
new methods to keep "records" up to date
unset flag HA_NOT_EXACT_COUNT to make handler read "records" field, for count() optim and join optimization
new methods to keep "records" up to datecorrect record field in ndbcluster handler
new method for ndbcluster handler to store/retrieve table and thread specific data
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
hanged deleteKey to return ponter to deleted object
moved heavy global cache fetch from inline to separate method
mysql-test/r/ndb_alter_table.result:
correct record field in ndbcluster handler
mysql-test/r/ndb_blob.result:
correct record field in ndbcluster handler
ndb/include/ndbapi/NdbDictionary.hpp:
new method for ndbcluster handler to store/retrieve table and thread specific data
ndb/src/ndbapi/DictCache.cpp:
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
ndb/src/ndbapi/DictCache.hpp:
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
ndb/src/ndbapi/Ndb.cpp:
replaced method DictionaryImpl::getTable with DictionaryImpl::get_local_table_info
ndb/src/ndbapi/NdbDictionary.cpp:
new method for ndbcluster handler to store/retrieve table and thread specific data
ndb/src/ndbapi/NdbDictionaryImpl.cpp:
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
moved heavy global cache fetch from inline to separate method
ndb/src/ndbapi/NdbDictionaryImpl.hpp:
replaced method DictionaryImpl::getTable with DictionaryImpl::get_local_table_info
ndb/src/ndbapi/NdbLinHash.hpp:
changed deleteKey to return ponter to deleted object
sql/ha_ndbcluster.cc:
moved all ndb thread specific data into new placeholder
new methods to keep "records" up to date
unset flag HA_NOT_EXACT_COUNT to make handler read "records" field, for count() optim and join optimization
sql/ha_ndbcluster.h:
new methods to keep "records" up to date
sql/sql_class.h:
moved all ndb thread specific data into new placeholder
2004-09-14 10:52:21 +02:00
|
|
|
t1 ndbcluster 9 Dynamic 0 0 0 NULL 0 0 1 NULL NULL NULL latin1_swedish_ci NULL
|
2004-09-15 18:44:18 +02:00
|
|
|
SET SQL_MODE=NO_AUTO_VALUE_ON_ZERO;
|
2004-08-10 14:38:24 +02:00
|
|
|
insert into t1 values
|
|
|
|
(0,4,3,5,"PENDING",1,7),(NULL,4,3,5,"PENDING",1,7),(31,4,3,5,"PENDING",1,7), (7,4,3,5,"PENDING",1,7), (NULL,4,3,5,"PENDING",1,7), (100,4,3,5,"PENDING",1,7), (99,4,3,5,"PENDING",1,7), (8,4,3,5,"PENDING",1,7), (NULL,4,3,5,"PENDING",1,7);
|
2004-08-12 10:15:53 +02:00
|
|
|
show table status;
|
|
|
|
Name Engine Version Row_format Rows Avg_row_length Data_length Max_data_length Index_length Data_free Auto_increment Create_time Update_time Check_time Collation Checksum Create_options Comment
|
moved all ndb thread specific data into new placeholder
new methods to keep "records" up to date
unset flag HA_NOT_EXACT_COUNT to make handler read "records" field, for count() optim and join optimization
new methods to keep "records" up to datecorrect record field in ndbcluster handler
new method for ndbcluster handler to store/retrieve table and thread specific data
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
hanged deleteKey to return ponter to deleted object
moved heavy global cache fetch from inline to separate method
mysql-test/r/ndb_alter_table.result:
correct record field in ndbcluster handler
mysql-test/r/ndb_blob.result:
correct record field in ndbcluster handler
ndb/include/ndbapi/NdbDictionary.hpp:
new method for ndbcluster handler to store/retrieve table and thread specific data
ndb/src/ndbapi/DictCache.cpp:
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
ndb/src/ndbapi/DictCache.hpp:
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
ndb/src/ndbapi/Ndb.cpp:
replaced method DictionaryImpl::getTable with DictionaryImpl::get_local_table_info
ndb/src/ndbapi/NdbDictionary.cpp:
new method for ndbcluster handler to store/retrieve table and thread specific data
ndb/src/ndbapi/NdbDictionaryImpl.cpp:
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
moved heavy global cache fetch from inline to separate method
ndb/src/ndbapi/NdbDictionaryImpl.hpp:
replaced method DictionaryImpl::getTable with DictionaryImpl::get_local_table_info
ndb/src/ndbapi/NdbLinHash.hpp:
changed deleteKey to return ponter to deleted object
sql/ha_ndbcluster.cc:
moved all ndb thread specific data into new placeholder
new methods to keep "records" up to date
unset flag HA_NOT_EXACT_COUNT to make handler read "records" field, for count() optim and join optimization
sql/ha_ndbcluster.h:
new methods to keep "records" up to date
sql/sql_class.h:
moved all ndb thread specific data into new placeholder
2004-09-14 10:52:21 +02:00
|
|
|
t1 ndbcluster 9 Dynamic 9 0 0 NULL 0 0 102 NULL NULL NULL latin1_swedish_ci NULL
|
2004-07-29 14:02:40 +02:00
|
|
|
select * from t1 order by col1;
|
|
|
|
col1 col2 col3 col4 col5 col6 to_be_deleted
|
2004-08-10 14:38:24 +02:00
|
|
|
0 4 3 5 PENDING 1 7
|
|
|
|
1 4 3 5 PENDING 1 7
|
|
|
|
7 4 3 5 PENDING 1 7
|
|
|
|
8 4 3 5 PENDING 1 7
|
|
|
|
31 4 3 5 PENDING 1 7
|
|
|
|
32 4 3 5 PENDING 1 7
|
|
|
|
99 4 3 5 PENDING 1 7
|
|
|
|
100 4 3 5 PENDING 1 7
|
|
|
|
101 4 3 5 PENDING 1 7
|
2004-05-05 16:04:23 +02:00
|
|
|
alter table t1
|
|
|
|
add column col4_5 varchar(20) not null after col4,
|
|
|
|
add column col7 varchar(30) not null after col5,
|
|
|
|
add column col8 datetime not null, drop column to_be_deleted,
|
|
|
|
change column col2 fourth varchar(30) not null after col3,
|
|
|
|
modify column col6 int not null first;
|
2004-08-12 10:15:53 +02:00
|
|
|
show table status;
|
|
|
|
Name Engine Version Row_format Rows Avg_row_length Data_length Max_data_length Index_length Data_free Auto_increment Create_time Update_time Check_time Collation Checksum Create_options Comment
|
moved all ndb thread specific data into new placeholder
new methods to keep "records" up to date
unset flag HA_NOT_EXACT_COUNT to make handler read "records" field, for count() optim and join optimization
new methods to keep "records" up to datecorrect record field in ndbcluster handler
new method for ndbcluster handler to store/retrieve table and thread specific data
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
hanged deleteKey to return ponter to deleted object
moved heavy global cache fetch from inline to separate method
mysql-test/r/ndb_alter_table.result:
correct record field in ndbcluster handler
mysql-test/r/ndb_blob.result:
correct record field in ndbcluster handler
ndb/include/ndbapi/NdbDictionary.hpp:
new method for ndbcluster handler to store/retrieve table and thread specific data
ndb/src/ndbapi/DictCache.cpp:
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
ndb/src/ndbapi/DictCache.hpp:
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
ndb/src/ndbapi/Ndb.cpp:
replaced method DictionaryImpl::getTable with DictionaryImpl::get_local_table_info
ndb/src/ndbapi/NdbDictionary.cpp:
new method for ndbcluster handler to store/retrieve table and thread specific data
ndb/src/ndbapi/NdbDictionaryImpl.cpp:
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
moved heavy global cache fetch from inline to separate method
ndb/src/ndbapi/NdbDictionaryImpl.hpp:
replaced method DictionaryImpl::getTable with DictionaryImpl::get_local_table_info
ndb/src/ndbapi/NdbLinHash.hpp:
changed deleteKey to return ponter to deleted object
sql/ha_ndbcluster.cc:
moved all ndb thread specific data into new placeholder
new methods to keep "records" up to date
unset flag HA_NOT_EXACT_COUNT to make handler read "records" field, for count() optim and join optimization
sql/ha_ndbcluster.h:
new methods to keep "records" up to date
sql/sql_class.h:
moved all ndb thread specific data into new placeholder
2004-09-14 10:52:21 +02:00
|
|
|
t1 ndbcluster 9 Dynamic 9 0 0 NULL 0 0 102 NULL NULL NULL latin1_swedish_ci NULL
|
2004-07-29 14:02:40 +02:00
|
|
|
select * from t1 order by col1;
|
2004-05-05 16:04:23 +02:00
|
|
|
col6 col1 col3 fourth col4 col4_5 col5 col7 col8
|
2004-08-10 14:38:24 +02:00
|
|
|
1 0 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 1 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 7 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 8 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 31 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 32 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 99 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 100 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 101 3 4 5 PENDING 0000-00-00 00:00:00
|
2004-07-29 14:02:40 +02:00
|
|
|
insert into t1 values (2, NULL,4,3,5,99,"PENDING","EXTRA",'2004-01-01 00:00:00');
|
2004-08-12 10:15:53 +02:00
|
|
|
show table status;
|
|
|
|
Name Engine Version Row_format Rows Avg_row_length Data_length Max_data_length Index_length Data_free Auto_increment Create_time Update_time Check_time Collation Checksum Create_options Comment
|
moved all ndb thread specific data into new placeholder
new methods to keep "records" up to date
unset flag HA_NOT_EXACT_COUNT to make handler read "records" field, for count() optim and join optimization
new methods to keep "records" up to datecorrect record field in ndbcluster handler
new method for ndbcluster handler to store/retrieve table and thread specific data
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
hanged deleteKey to return ponter to deleted object
moved heavy global cache fetch from inline to separate method
mysql-test/r/ndb_alter_table.result:
correct record field in ndbcluster handler
mysql-test/r/ndb_blob.result:
correct record field in ndbcluster handler
ndb/include/ndbapi/NdbDictionary.hpp:
new method for ndbcluster handler to store/retrieve table and thread specific data
ndb/src/ndbapi/DictCache.cpp:
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
ndb/src/ndbapi/DictCache.hpp:
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
ndb/src/ndbapi/Ndb.cpp:
replaced method DictionaryImpl::getTable with DictionaryImpl::get_local_table_info
ndb/src/ndbapi/NdbDictionary.cpp:
new method for ndbcluster handler to store/retrieve table and thread specific data
ndb/src/ndbapi/NdbDictionaryImpl.cpp:
changed local hash to store new table_info object, with placeholders for local data, instead of TableImpl
moved heavy global cache fetch from inline to separate method
ndb/src/ndbapi/NdbDictionaryImpl.hpp:
replaced method DictionaryImpl::getTable with DictionaryImpl::get_local_table_info
ndb/src/ndbapi/NdbLinHash.hpp:
changed deleteKey to return ponter to deleted object
sql/ha_ndbcluster.cc:
moved all ndb thread specific data into new placeholder
new methods to keep "records" up to date
unset flag HA_NOT_EXACT_COUNT to make handler read "records" field, for count() optim and join optimization
sql/ha_ndbcluster.h:
new methods to keep "records" up to date
sql/sql_class.h:
moved all ndb thread specific data into new placeholder
2004-09-14 10:52:21 +02:00
|
|
|
t1 ndbcluster 9 Dynamic 10 0 0 NULL 0 0 103 NULL NULL NULL latin1_swedish_ci NULL
|
2004-07-29 14:02:40 +02:00
|
|
|
select * from t1 order by col1;
|
|
|
|
col6 col1 col3 fourth col4 col4_5 col5 col7 col8
|
2004-08-10 14:38:24 +02:00
|
|
|
1 0 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 1 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 7 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 8 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 31 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 32 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 99 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 100 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
1 101 3 4 5 PENDING 0000-00-00 00:00:00
|
|
|
|
2 102 4 3 5 99 PENDING EXTRA 2004-01-01 00:00:00
|
2004-09-26 17:11:28 +02:00
|
|
|
delete from t1;
|
|
|
|
insert into t1 values (0,0,4,3,5,99,"PENDING","EXTRA",'2004-01-01 00:00:00');
|
|
|
|
SET SQL_MODE='';
|
|
|
|
insert into t1 values (1,0,4,3,5,99,"PENDING","EXTRA",'2004-01-01 00:00:00');
|
|
|
|
select * from t1 order by col1;
|
|
|
|
col6 col1 col3 fourth col4 col4_5 col5 col7 col8
|
|
|
|
0 0 4 3 5 99 PENDING EXTRA 2004-01-01 00:00:00
|
|
|
|
1 103 4 3 5 99 PENDING EXTRA 2004-01-01 00:00:00
|
|
|
|
alter table t1 drop column col4_5;
|
|
|
|
insert into t1 values (2,0,4,3,5,"PENDING","EXTRA",'2004-01-01 00:00:00');
|
|
|
|
select * from t1 order by col1;
|
|
|
|
col6 col1 col3 fourth col4 col5 col7 col8
|
|
|
|
0 0 4 3 5 PENDING EXTRA 2004-01-01 00:00:00
|
|
|
|
1 103 4 3 5 PENDING EXTRA 2004-01-01 00:00:00
|
|
|
|
2 104 4 3 5 PENDING EXTRA 2004-01-01 00:00:00
|
2004-05-05 16:04:23 +02:00
|
|
|
drop table t1;
|
2004-09-24 18:58:25 +02:00
|
|
|
CREATE TABLE t1 (
|
|
|
|
a INT NOT NULL,
|
|
|
|
b INT NOT NULL
|
|
|
|
) ENGINE=ndbcluster;
|
|
|
|
INSERT INTO t1 VALUES (9410,9412);
|
|
|
|
ALTER TABLE t1 ADD COLUMN c int not null;
|
2004-09-28 09:53:14 +02:00
|
|
|
select * from t1 order by a;
|
2004-09-24 18:58:25 +02:00
|
|
|
a b c
|
|
|
|
9410 9412 0
|
2004-09-28 09:53:14 +02:00
|
|
|
select * from t1 order by a;
|
2004-09-24 18:58:25 +02:00
|
|
|
a b c
|
|
|
|
9410 9412 0
|
|
|
|
alter table t1 drop c;
|
2004-09-28 09:53:14 +02:00
|
|
|
select * from t1 order by a;
|
2004-09-24 18:58:25 +02:00
|
|
|
a b
|
|
|
|
9410 9412
|
|
|
|
drop table t1;
|
2004-09-28 09:53:14 +02:00
|
|
|
select * from t1 order by a;
|
2004-09-24 18:58:25 +02:00
|
|
|
ERROR 42S02: Table 'test.t1' doesn't exist
|
2004-09-28 09:53:14 +02:00
|
|
|
CREATE TABLE t1 (
|
|
|
|
a INT NOT NULL PRIMARY KEY,
|
|
|
|
b INT NOT NULL
|
|
|
|
) ENGINE=ndbcluster;
|
|
|
|
INSERT INTO t1 VALUES (0,1),(17,18);
|
|
|
|
select * from t1 order by a;
|
|
|
|
a b
|
|
|
|
0 1
|
|
|
|
17 18
|
2004-10-07 18:30:21 +02:00
|
|
|
SET SQL_MODE=NO_AUTO_VALUE_ON_ZERO;
|
2004-09-28 09:53:14 +02:00
|
|
|
alter table t1 modify column a int not null auto_increment;
|
2004-10-07 18:30:21 +02:00
|
|
|
SET SQL_MODE='';
|
2004-09-28 09:53:14 +02:00
|
|
|
select * from t1 order by a;
|
|
|
|
a b
|
|
|
|
0 1
|
|
|
|
17 18
|
|
|
|
INSERT INTO t1 VALUES (0,19),(20,21);
|
|
|
|
select * from t1 order by a;
|
|
|
|
a b
|
|
|
|
0 1
|
|
|
|
17 18
|
|
|
|
18 19
|
|
|
|
20 21
|
|
|
|
drop table t1;
|
|
|
|
CREATE TABLE t1 (
|
|
|
|
a INT NOT NULL PRIMARY KEY,
|
|
|
|
b INT NOT NULL
|
|
|
|
) ENGINE=ndbcluster;
|
|
|
|
INSERT INTO t1 VALUES (0,1),(17,18);
|
2004-10-01 14:23:31 +02:00
|
|
|
select * from t1 order by a;
|
2004-09-28 09:53:14 +02:00
|
|
|
a b
|
|
|
|
0 1
|
2004-10-01 14:23:31 +02:00
|
|
|
17 18
|
2004-09-28 09:53:14 +02:00
|
|
|
alter table t1 add c int not null unique auto_increment;
|
2004-10-01 14:23:31 +02:00
|
|
|
select c from t1 order by c;
|
|
|
|
c
|
|
|
|
1
|
|
|
|
2
|
|
|
|
INSERT INTO t1 VALUES (1,2,0),(18,19,4),(20,21,0);
|
|
|
|
select c from t1 order by c;
|
|
|
|
c
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
5
|
2004-09-28 09:53:14 +02:00
|
|
|
drop table t1;
|
2005-03-07 10:21:38 +01:00
|
|
|
create table t1 ( a int primary key, b varchar(10), c varchar(10), index (b) )
|
|
|
|
engine=ndb;
|
|
|
|
insert into t1 values (1,'one','one'), (2,'two','two'), (3,'three','three');
|
|
|
|
create index c on t1(c);
|
|
|
|
select * from t1 where b = 'two';
|
|
|
|
a b c
|
|
|
|
2 two two
|
|
|
|
alter table t1 drop index c;
|
|
|
|
select * from t1 where b = 'two';
|
2005-04-04 12:26:05 +02:00
|
|
|
ERROR HY000: Table definition has changed, please retry transaction
|
2005-03-07 10:21:38 +01:00
|
|
|
select * from t1 where b = 'two';
|
|
|
|
a b c
|
|
|
|
2 two two
|
|
|
|
drop table t1;
|