mirror of
https://github.com/MariaDB/server.git
synced 2025-01-19 13:32:33 +01:00
06fb8c2d10
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. mysql-test/extra/rpl_tests/rpl_extraMaster_Col.test: Sorting by columns that produces deterministic order. mysql-test/suite/rpl/r/rpl_extraColmaster_innodb.result: Result change. mysql-test/suite/rpl/r/rpl_extraColmaster_myisam.result: Result change. mysql-test/suite/rpl/r/rpl_row_extraColmaster_ndb.result: Result change. mysql-test/suite/rpl/t/disabled.def: Enabling tests. mysql-test/suite/rpl/t/rpl_row_mysqlbinlog.test: Adding missing sync_slave_with_master causing slave to keep tables after shutdown. mysql-test/suite/rpl_ndb/t/disabled.def: Enabling tests. mysql-test/suite/rpl_ndb/t/rpl_ndb_innodb2ndb-slave.opt: Adding --new option mysql-test/suite/rpl_ndb/t/rpl_ndb_innodb2ndb.test: Adding have_log_bin. mysql-test/suite/rpl_ndb/t/rpl_ndb_myisam2ndb-slave.opt: Adding --new option mysql-test/suite/rpl_ndb/t/rpl_ndb_myisam2ndb.test: Adding have_log_bin mysql-test/t/partition.test: Adding have_archive, since that is used in the test. sql/field.cc: Eliminating all two-argument pack() and unpack() functions and moving functionality into the four-argument version. The four argument version is introduced so that it is possible to avoid using the storage engine default when writing and reading the packed format (the unpacked format still uses the storage engine's default). This is used by row-based replication to write the fields in a storage engine- and endian-agnostic format. Packing integral and floating-point numbers in little-endian format (if requested). Using pad_char for the field instead of spaces (0x20) when unpacking. Adding some Doxygen documentation. --- Adding max_data_length() to denote the maximum number of bytes that pack() will write. Adding casts to remove warnings for debug printouts. sql/field.h: Eliminating all virtual pack() and unpack() functions except the four- argument version, which now is the function that shall be overridden. The two-argument versions are convenience functions, to prevent changes to code that uses these. Adding code to pack integer numbers and floating-point numbers in little-endian format, if requested. --- Adding max_data_length() to denote the maximum number of bytes that pack() will write. sql/log.cc: Removing debug printout causing crash when starting NDB on Solaris. sql/log_event.cc: Adding missing #ifndef causing compile failure. Adding debug printouts. sql/rpl_record.cc: Debriding code. Using new pack() and unpack() functions to always pack fields little-endian. Adding debug printouts. --- Using max_data_length() when packing field into row. Adding casts to debug printouts. sql/sql_show.cc: Adding code that causes crash on Solaris machines since printf() cannot handle NULL values for strings properly. mysql-test/suite/rpl_ndb/r/rpl_ndb_innodb2ndb.result: New BitKeeper file ``mysql-test/suite/rpl_ndb/r/rpl_ndb_innodb2ndb.result'' mysql-test/suite/rpl_ndb/r/rpl_ndb_myisam2ndb.result: New BitKeeper file ``mysql-test/suite/rpl_ndb/r/rpl_ndb_myisam2ndb.result''
1364 lines
37 KiB
Text
1364 lines
37 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;
|
||
set binlog_format=row;
|
||
CREATE TABLE t1 (f1 INT, f2 INT, f3 INT PRIMARY KEY, f4 CHAR(20),
|
||
f5 FLOAT DEFAULT '2.00')
|
||
ENGINE='InnoDB';
|
||
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='InnoDB';
|
||
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='InnoDB';
|
||
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='InnoDB';
|
||
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='InnoDB';
|
||
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='InnoDB';
|
||
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='InnoDB';
|
||
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 |