mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 06:44:16 +01:00
c4298a3fb9
Refactoring code to add parameter to pack() and unpack() functions with purpose of indicating if data should be packed in little-endian or native order. Using new functions to always pack data for binary log in little-endian order. The purpose of this refactoring is to allow proper implementation of endian-agnostic pack() and unpack() functions. Eliminating several versions of virtual pack() and unpack() functions in favor for one single virtual function which is overridden in subclasses. Implementing pack() and unpack() functions for some field types that packed data in native format regardless of the value of the st_table_share::db_low_byte_first flag. The field types that were packed in native format regardless are: Field_real, Field_decimal, Field_tiny, Field_short, Field_medium, Field_long, Field_longlong, and Field_blob. Before the patch, row-based logging wrote the rows incorrectly on big-endian machines where the storage engine defined its own low_byte_first() to be FALSE on big-endian machines (the default is TRUE), while little-endian machines wrote the fields in correct order. The only known storage engine that does this is NDB. In effect, this means that row-based replication from or to a big-endian machine where the table was using NDB as storage engine failed if the other engine was either non-NDB or on a little-endian machine. With this patch, row-based logging is now always done in little-endian order, while ORDER BY uses the native order if the storage engine defines low_byte_first() to return FALSE for big-endian machines. In addition, the max_data_length() function available in Field_blob was generalized to the entire Field hierarchy to give the maximum number of bytes that Field::pack() will write.
684 lines
19 KiB
Text
684 lines
19 KiB
Text
stop slave;
|
||
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
|
||
reset master;
|
||
reset slave;
|
||
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
|
||
start slave;
|
||
CREATE TABLE t1 (f1 INT, f2 INT, f3 INT PRIMARY KEY, f4 CHAR(20),
|
||
f5 FLOAT DEFAULT '2.00')
|
||
ENGINE='NDB';
|
||
alter table t1 drop f5;
|
||
INSERT into t1 values (1, 1, 1, 'first', 1.0);
|
||
show slave status;;
|
||
Slave_IO_State #
|
||
Master_Host 127.0.0.1
|
||
Master_User root
|
||
Master_Port #
|
||
Connect_Retry 1
|
||
Master_Log_File master-bin.000001
|
||
Read_Master_Log_Pos #
|
||
Relay_Log_File #
|
||
Relay_Log_Pos #
|
||
Relay_Master_Log_File master-bin.000001
|
||
Slave_IO_Running Yes
|
||
Slave_SQL_Running Yes
|
||
Replicate_Do_DB
|
||
Replicate_Ignore_DB
|
||
Replicate_Do_Table
|
||
Replicate_Ignore_Table
|
||
Replicate_Wild_Do_Table
|
||
Replicate_Wild_Ignore_Table
|
||
Last_Errno 0
|
||
Last_Error
|
||
Skip_Counter 0
|
||
Exec_Master_Log_Pos #
|
||
Relay_Log_Space #
|
||
Until_Condition None
|
||
Until_Log_File
|
||
Until_Log_Pos 0
|
||
Master_SSL_Allowed No
|
||
Master_SSL_CA_File
|
||
Master_SSL_CA_Path
|
||
Master_SSL_Cert
|
||
Master_SSL_Cipher
|
||
Master_SSL_Key
|
||
Seconds_Behind_Master #
|
||
Master_SSL_Verify_Server_Cert No
|
||
Last_IO_Errno 0
|
||
Last_IO_Error
|
||
Last_SQL_Errno 0
|
||
Last_SQL_Error
|
||
select * from t1 order by f3;
|
||
f1 f2 f3 f4
|
||
1 1 1 first
|
||
DROP TABLE t1;
|
||
CREATE TABLE t1 (f1 INT, f2 INT, f3 INT PRIMARY KEY, f4 CHAR(20),
|
||
f5 FLOAT DEFAULT '2.00',
|
||
f6 CHAR(4) DEFAULT 'TEST')
|
||
ENGINE='NDB';
|
||
alter table t1 drop f5, drop f6;
|
||
INSERT into t1 values (1, 1, 1, 'first', 1.0, 'yksi');
|
||
show slave status;;
|
||
Slave_IO_State #
|
||
Master_Host 127.0.0.1
|
||
Master_User root
|
||
Master_Port #
|
||
Connect_Retry 1
|
||
Master_Log_File master-bin.000001
|
||
Read_Master_Log_Pos #
|
||
Relay_Log_File #
|
||
Relay_Log_Pos #
|
||
Relay_Master_Log_File master-bin.000001
|
||
Slave_IO_Running Yes
|
||
Slave_SQL_Running Yes
|
||
Replicate_Do_DB
|
||
Replicate_Ignore_DB
|
||
Replicate_Do_Table
|
||
Replicate_Ignore_Table
|
||
Replicate_Wild_Do_Table
|
||
Replicate_Wild_Ignore_Table
|
||
Last_Errno 0
|
||
Last_Error
|
||
Skip_Counter 0
|
||
Exec_Master_Log_Pos #
|
||
Relay_Log_Space #
|
||
Until_Condition None
|
||
Until_Log_File
|
||
Until_Log_Pos 0
|
||
Master_SSL_Allowed No
|
||
Master_SSL_CA_File
|
||
Master_SSL_CA_Path
|
||
Master_SSL_Cert
|
||
Master_SSL_Cipher
|
||
Master_SSL_Key
|
||
Seconds_Behind_Master #
|
||
Master_SSL_Verify_Server_Cert No
|
||
Last_IO_Errno 0
|
||
Last_IO_Error
|
||
Last_SQL_Errno 0
|
||
Last_SQL_Error
|
||
select * from t1 order by f3;
|
||
f1 f2 f3 f4
|
||
1 1 1 first
|
||
DROP TABLE t1;
|
||
CREATE TABLE t1 (f1 INT, f2 INT, f3 INT PRIMARY KEY, f4 CHAR(20),
|
||
f5 FLOAT DEFAULT '2.00',
|
||
f6 CHAR(4) DEFAULT 'TEST',
|
||
f7 INT DEFAULT '0')
|
||
ENGINE='NDB';
|
||
alter table t1 drop f5, drop f6, drop f7;
|
||
INSERT into t1 values (1, 1, 1, 'first', 1.0, 'yksi', 1);
|
||
show slave status;;
|
||
Slave_IO_State #
|
||
Master_Host 127.0.0.1
|
||
Master_User root
|
||
Master_Port #
|
||
Connect_Retry 1
|
||
Master_Log_File master-bin.000001
|
||
Read_Master_Log_Pos #
|
||
Relay_Log_File #
|
||
Relay_Log_Pos #
|
||
Relay_Master_Log_File master-bin.000001
|
||
Slave_IO_Running Yes
|
||
Slave_SQL_Running Yes
|
||
Replicate_Do_DB
|
||
Replicate_Ignore_DB
|
||
Replicate_Do_Table
|
||
Replicate_Ignore_Table
|
||
Replicate_Wild_Do_Table
|
||
Replicate_Wild_Ignore_Table
|
||
Last_Errno 0
|
||
Last_Error
|
||
Skip_Counter 0
|
||
Exec_Master_Log_Pos #
|
||
Relay_Log_Space #
|
||
Until_Condition None
|
||
Until_Log_File
|
||
Until_Log_Pos 0
|
||
Master_SSL_Allowed No
|
||
Master_SSL_CA_File
|
||
Master_SSL_CA_Path
|
||
Master_SSL_Cert
|
||
Master_SSL_Cipher
|
||
Master_SSL_Key
|
||
Seconds_Behind_Master #
|
||
Master_SSL_Verify_Server_Cert No
|
||
Last_IO_Errno 0
|
||
Last_IO_Error
|
||
Last_SQL_Errno 0
|
||
Last_SQL_Error
|
||
select * from t1 order by f3;
|
||
f1 f2 f3 f4
|
||
1 1 1 first
|
||
DROP TABLE t1;
|
||
CREATE TABLE t1 (f1 INT, f2 INT, f3 INT PRIMARY KEY, f4 CHAR(20),
|
||
f5 FLOAT DEFAULT '2.00',
|
||
f6 CHAR(4) DEFAULT 'TEST',
|
||
f7 INT DEFAULT '0',
|
||
f8 TEXT)
|
||
ENGINE='NDB';
|
||
alter table t1 drop f5, drop f6, drop f7, drop f8;
|
||
INSERT into t1 values (1, 1, 1, 'first', 1.0, 'yksi', 1, 'lounge of happiness');
|
||
show slave status;;
|
||
Slave_IO_State #
|
||
Master_Host 127.0.0.1
|
||
Master_User root
|
||
Master_Port #
|
||
Connect_Retry 1
|
||
Master_Log_File master-bin.000001
|
||
Read_Master_Log_Pos #
|
||
Relay_Log_File #
|
||
Relay_Log_Pos #
|
||
Relay_Master_Log_File master-bin.000001
|
||
Slave_IO_Running Yes
|
||
Slave_SQL_Running Yes
|
||
Replicate_Do_DB
|
||
Replicate_Ignore_DB
|
||
Replicate_Do_Table
|
||
Replicate_Ignore_Table
|
||
Replicate_Wild_Do_Table
|
||
Replicate_Wild_Ignore_Table
|
||
Last_Errno 0
|
||
Last_Error
|
||
Skip_Counter 0
|
||
Exec_Master_Log_Pos #
|
||
Relay_Log_Space #
|
||
Until_Condition None
|
||
Until_Log_File
|
||
Until_Log_Pos 0
|
||
Master_SSL_Allowed No
|
||
Master_SSL_CA_File
|
||
Master_SSL_CA_Path
|
||
Master_SSL_Cert
|
||
Master_SSL_Cipher
|
||
Master_SSL_Key
|
||
Seconds_Behind_Master #
|
||
Master_SSL_Verify_Server_Cert No
|
||
Last_IO_Errno 0
|
||
Last_IO_Error
|
||
Last_SQL_Errno 0
|
||
Last_SQL_Error
|
||
select * from t1 order by f3;
|
||
f1 f2 f3 f4
|
||
1 1 1 first
|
||
DROP TABLE t1;
|
||
CREATE TABLE t1 (f1 INT, f2 INT, f3 INT PRIMARY KEY, f4 CHAR(20),
|
||
f5 FLOAT DEFAULT '2.00',
|
||
f6 CHAR(4) DEFAULT 'TEST',
|
||
f7 INT DEFAULT '0',
|
||
f8 TEXT,
|
||
f9 LONGBLOB)
|
||
ENGINE='NDB';
|
||
alter table t1 drop f5, drop f6, drop f7, drop f8, drop f9;
|
||
INSERT into t1 values (1, 1, 1, 'first', 1.0, 'yksi', 1, 'lounge of happiness', 'very fat blob');
|
||
show slave status;;
|
||
Slave_IO_State #
|
||
Master_Host 127.0.0.1
|
||
Master_User root
|
||
Master_Port #
|
||
Connect_Retry 1
|
||
Master_Log_File master-bin.000001
|
||
Read_Master_Log_Pos #
|
||
Relay_Log_File #
|
||
Relay_Log_Pos #
|
||
Relay_Master_Log_File master-bin.000001
|
||
Slave_IO_Running Yes
|
||
Slave_SQL_Running Yes
|
||
Replicate_Do_DB
|
||
Replicate_Ignore_DB
|
||
Replicate_Do_Table
|
||
Replicate_Ignore_Table
|
||
Replicate_Wild_Do_Table
|
||
Replicate_Wild_Ignore_Table
|
||
Last_Errno 0
|
||
Last_Error
|
||
Skip_Counter 0
|
||
Exec_Master_Log_Pos #
|
||
Relay_Log_Space #
|
||
Until_Condition None
|
||
Until_Log_File
|
||
Until_Log_Pos 0
|
||
Master_SSL_Allowed No
|
||
Master_SSL_CA_File
|
||
Master_SSL_CA_Path
|
||
Master_SSL_Cert
|
||
Master_SSL_Cipher
|
||
Master_SSL_Key
|
||
Seconds_Behind_Master #
|
||
Master_SSL_Verify_Server_Cert No
|
||
Last_IO_Errno 0
|
||
Last_IO_Error
|
||
Last_SQL_Errno 0
|
||
Last_SQL_Error
|
||
select * from t1 order by f3;
|
||
f1 f2 f3 f4
|
||
1 1 1 first
|
||
DROP TABLE t1;
|
||
CREATE TABLE t1 (f1 INT, f2 INT, f3 INT PRIMARY KEY, f4 CHAR(20),
|
||
f5 FLOAT DEFAULT '2.00',
|
||
f6 CHAR(4) DEFAULT 'TEST',
|
||
f7 INT DEFAULT '0',
|
||
f8 TEXT,
|
||
f9 LONGBLOB,
|
||
f10 BIT(63))
|
||
ENGINE='NDB';
|
||
alter table t1 drop f5, drop f6, drop f7, drop f8, drop f9, drop f10;
|
||
INSERT into t1 values (1, 1, 1, 'first', 1.0, 'yksi', 1, 'lounge of happiness', 'very fat blob', b'01010101010101');
|
||
show slave status;;
|
||
Slave_IO_State #
|
||
Master_Host 127.0.0.1
|
||
Master_User root
|
||
Master_Port #
|
||
Connect_Retry 1
|
||
Master_Log_File master-bin.000001
|
||
Read_Master_Log_Pos #
|
||
Relay_Log_File #
|
||
Relay_Log_Pos #
|
||
Relay_Master_Log_File master-bin.000001
|
||
Slave_IO_Running Yes
|
||
Slave_SQL_Running Yes
|
||
Replicate_Do_DB
|
||
Replicate_Ignore_DB
|
||
Replicate_Do_Table
|
||
Replicate_Ignore_Table
|
||
Replicate_Wild_Do_Table
|
||
Replicate_Wild_Ignore_Table
|
||
Last_Errno 0
|
||
Last_Error
|
||
Skip_Counter 0
|
||
Exec_Master_Log_Pos #
|
||
Relay_Log_Space #
|
||
Until_Condition None
|
||
Until_Log_File
|
||
Until_Log_Pos 0
|
||
Master_SSL_Allowed No
|
||
Master_SSL_CA_File
|
||
Master_SSL_CA_Path
|
||
Master_SSL_Cert
|
||
Master_SSL_Cipher
|
||
Master_SSL_Key
|
||
Seconds_Behind_Master #
|
||
Master_SSL_Verify_Server_Cert No
|
||
Last_IO_Errno 0
|
||
Last_IO_Error
|
||
Last_SQL_Errno 0
|
||
Last_SQL_Error
|
||
select * from t1 order by f3;
|
||
f1 f2 f3 f4
|
||
1 1 1 first
|
||
DROP TABLE t1;
|
||
CREATE TABLE t1 (f1 INT, f2 INT, f3 INT PRIMARY KEY, f4 CHAR(20),
|
||
/* extra */
|
||
f5 FLOAT DEFAULT '2.00',
|
||
f6 CHAR(4) DEFAULT 'TEST',
|
||
f7 INT DEFAULT '0',
|
||
f8 TEXT,
|
||
f9 LONGBLOB,
|
||
f10 BIT(63),
|
||
f11 VARBINARY(64))
|
||
ENGINE='NDB';
|
||
alter table t1 drop f5, drop f6, drop f7, drop f8, drop f9, drop f10, drop f11;
|
||
INSERT into t1 values (1, 1, 1, 'first', 1.0, 'yksi', 1, 'lounge of happiness', 'very fat blob', b'01010101010101', 0x123456);
|
||
INSERT into t1 values (2, 2, 2, 'second', 2.0, 'kaks', 2, 'got stolen from the paradise', 'very fat blob', b'01010101010101', 0x123456), (3, 3, 3, 'third', 3.0, 'kolm', 3, 'got stolen from the paradise', 'very fat blob', b'01010101010101', 0x123456);
|
||
update t1 set f4= 'next' where f1=1;
|
||
delete from t1 where f1=1;
|
||
select * from t1 order by f3;
|
||
f1 f2 f3 f4 f5 f6 f7 f8 f9 f10 f11
|
||
2 2 2 second 2 kaks 2 got stolen from the paradise very fat blob |