merge from 5.1 main
This commit is contained in:
commit
10ec4d1544
@ -126,7 +126,9 @@ struct tm *gmtime_r(const time_t *timep,struct tm *tmp);
|
|||||||
|
|
||||||
void pthread_exit(void *a); /* was #define pthread_exit(A) ExitThread(A)*/
|
void pthread_exit(void *a); /* was #define pthread_exit(A) ExitThread(A)*/
|
||||||
|
|
||||||
#define ETIMEDOUT 145 /* Win32 doesn't have this */
|
#ifndef ETIMEDOUT
|
||||||
|
#define ETIMEDOUT 145 /* Win32 might not have this */
|
||||||
|
#endif
|
||||||
#define getpid() GetCurrentThreadId()
|
#define getpid() GetCurrentThreadId()
|
||||||
#define HAVE_LOCALTIME_R 1
|
#define HAVE_LOCALTIME_R 1
|
||||||
#define _REENTRANT 1
|
#define _REENTRANT 1
|
||||||
|
@ -664,6 +664,7 @@ extern void init_glob_errs(void);
|
|||||||
extern void wait_for_free_space(const char *filename, int errors);
|
extern void wait_for_free_space(const char *filename, int errors);
|
||||||
extern FILE *my_fopen(const char *FileName,int Flags,myf MyFlags);
|
extern FILE *my_fopen(const char *FileName,int Flags,myf MyFlags);
|
||||||
extern FILE *my_fdopen(File Filedes,const char *name, int Flags,myf MyFlags);
|
extern FILE *my_fdopen(File Filedes,const char *name, int Flags,myf MyFlags);
|
||||||
|
extern FILE *my_freopen(const char *path, const char *mode, FILE *stream);
|
||||||
extern int my_fclose(FILE *fd,myf MyFlags);
|
extern int my_fclose(FILE *fd,myf MyFlags);
|
||||||
extern int my_chsize(File fd,my_off_t newlength, int filler, myf MyFlags);
|
extern int my_chsize(File fd,my_off_t newlength, int filler, myf MyFlags);
|
||||||
extern int my_sync(File fd, myf my_flags);
|
extern int my_sync(File fd, myf my_flags);
|
||||||
|
8
mysql-test/collections/default.weekly
Normal file → Executable file
8
mysql-test/collections/default.weekly
Normal file → Executable file
@ -1,2 +1,8 @@
|
|||||||
perl mysql-test-run.pl --timer --force --comment=1st --experimental=collections/default.experimental 1st
|
perl mysql-test-run.pl --timer --force --comment=1st --experimental=collections/default.experimental 1st
|
||||||
perl mysql-test-run.pl --timer --force --comment=big-tests --experimental=collections/default.experimental --vardir=var-big-tests --big-test --testcase-timeout=60 --suite-timeout=600 parts.partition_alter1_2_ndb parts.part_supported_sql_func_innodb parts.partition_alter1_2_innodb parts.partition_alter4_innodb parts.partition_alter1_1_2_ndb parts.partition_alter1_1_2_innodb parts.partition_alter1_1_ndb rpl_ndb.rpl_truncate_7ndb_2 main.archive-big main.sum_distinct-big main.mysqlbinlog_row_big main.alter_table-big main.variables-big main.type_newdecimal-big main.read_many_rows_innodb main.log_tables-big main.count_distinct3 main.events_time_zone main.merge-big main.create-big main.events_stress main.ssl-big
|
perl mysql-test-run.pl --timer --force --comment=big-tests --experimental=collections/default.experimental --vardir=var-big-tests --big-test --testcase-timeout=60 --suite-timeout=600 parts.partition_alter1_2_ndb parts.part_supported_sql_func_innodb parts.partition_alter1_2_innodb parts.partition_alter4_innodb parts.partition_alter1_1_2_ndb parts.partition_alter1_1_2_innodb parts.partition_alter1_1_ndb rpl_ndb.rpl_truncate_7ndb_2 main.archive-big main.sum_distinct-big main.mysqlbinlog_row_big main.alter_table-big main.variables-big main.type_newdecimal-big main.read_many_rows_innodb main.log_tables-big main.count_distinct3 main.events_time_zone main.merge-big main.create-big main.events_stress main.ssl-big funcs_1.myisam_views-big
|
||||||
|
perl mysql-test-run.pl --timer --force --parallel=auto --comment=eits-tests-myisam-engine --experimental=collections/default.experimental --vardir=var-stmt-eits-tests-myisam-engine --suite=engines/iuds,engines/funcs --suite-timeout=500 --max-test-fail=0 --retry-failure=0 --mysqld=--default-storage-engine=myisam
|
||||||
|
perl mysql-test-run.pl --timer --force --parallel=auto --comment=eits-rpl-binlog-row-tests-myisam-engine --experimental=collections/default.experimental --vardir=var-binlog-row-eits-tests-myisam-engine --suite=engines/iuds,engines/funcs --suite-timeout=500 --max-test-fail=0 --retry-failure=0 --mysqld=--default-storage-engine=myisam --do-test=rpl --mysqld=--binlog-format=row
|
||||||
|
perl mysql-test-run.pl --timer --force --parallel=auto --comment=eits-rpl-binlog-mixed-tests-myisam-engine --experimental=collections/default.experimental --vardir=var-binlog-mixed-eits-tests-myisam-engine --suite=engines/iuds,engines/funcs --suite-timeout=500 --max-test-fail=0 --retry-failure=0 --mysqld=--default-storage-engine=myisam --do-test=rpl --mysqld=--binlog-format=mixed
|
||||||
|
perl mysql-test-run.pl --timer --force --parallel=auto --comment=eits-tests-innodb-engine --experimental=collections/default.experimental --vardir=var-stmt-eits-tests-innodb-engine --suite=engines/iuds,engines/funcs --suite-timeout=500 --max-test-fail=0 --retry-failure=0 --mysqld=--default-storage-engine=innodb --mysqld=--innodb
|
||||||
|
perl mysql-test-run.pl --timer --force --parallel=auto --comment=eits-rpl-binlog-row-tests-innodb-engine --experimental=collections/default.experimental --vardir=var-binlog-row-eits-tests-innodb-engine --suite=engines/iuds,engines/funcs --suite-timeout=500 --max-test-fail=0 --retry-failure=0 --mysqld=--default-storage-engine=innodb --mysqld=--innodb --do-test=rpl --mysqld=--binlog-format=row
|
||||||
|
perl mysql-test-run.pl --timer --force --parallel=auto --comment=eits-rpl-binlog-mixed-tests-innodb-engine --experimental=collections/default.experimental --vardir=var-binlog-mixed-eits-tests-innodb-engine --suite=engines/iuds,engines/funcs --suite-timeout=500 --max-test-fail=0 --retry-failure=0 --mysqld=--default-storage-engine=innodb --mysqld=--innodb --do-test=rpl --mysqld=--binlog-format=mixed
|
||||||
|
@ -497,3 +497,22 @@ SET @@SESSION.AUTO_INCREMENT_INCREMENT=default;
|
|||||||
SET @@SESSION.AUTO_INCREMENT_OFFSET=default;
|
SET @@SESSION.AUTO_INCREMENT_OFFSET=default;
|
||||||
DROP TABLE t1;
|
DROP TABLE t1;
|
||||||
End of 5.1 tests
|
End of 5.1 tests
|
||||||
|
#
|
||||||
|
# Bug#50619 assert in handler::update_auto_increment
|
||||||
|
#
|
||||||
|
CREATE TABLE t1 (pk INT AUTO_INCREMENT, PRIMARY KEY (pk));
|
||||||
|
INSERT INTO t1 VALUES (NULL), (-1), (NULL);
|
||||||
|
SELECT * FROM t1;
|
||||||
|
pk
|
||||||
|
-1
|
||||||
|
1
|
||||||
|
2
|
||||||
|
DROP TABLE t1;
|
||||||
|
CREATE TABLE t1 (pk BIGINT UNSIGNED AUTO_INCREMENT, PRIMARY KEY (pk));
|
||||||
|
INSERT INTO t1 VALUES (NULL), (18446744073709551615-1), (NULL);
|
||||||
|
ERROR HY000: Failed to read auto-increment value from storage engine
|
||||||
|
SELECT * FROM t1;
|
||||||
|
pk
|
||||||
|
1
|
||||||
|
18446744073709551614
|
||||||
|
DROP TABLE t1;
|
||||||
|
@ -10,25 +10,166 @@ File Position Binlog_Do_DB Binlog_Ignore_DB
|
|||||||
master-bin.000001 106
|
master-bin.000001 106
|
||||||
stop slave;
|
stop slave;
|
||||||
reset slave;
|
reset slave;
|
||||||
|
show slave status;
|
||||||
|
Slave_IO_State #
|
||||||
|
Master_Host 127.0.0.1
|
||||||
|
Master_User root
|
||||||
|
Master_Port MASTER_PORT
|
||||||
|
Connect_Retry #
|
||||||
Master_Log_File
|
Master_Log_File
|
||||||
Read_Master_Log_Pos 4
|
Read_Master_Log_Pos 4
|
||||||
|
Relay_Log_File #
|
||||||
|
Relay_Log_Pos #
|
||||||
Relay_Master_Log_File
|
Relay_Master_Log_File
|
||||||
|
Slave_IO_Running No
|
||||||
|
Slave_SQL_Running No
|
||||||
|
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 0
|
Exec_Master_Log_Pos 0
|
||||||
|
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
|
||||||
change master to master_host='127.0.0.1';
|
change master to master_host='127.0.0.1';
|
||||||
|
show slave status;
|
||||||
|
Slave_IO_State #
|
||||||
|
Master_Host 127.0.0.1
|
||||||
|
Master_User root
|
||||||
|
Master_Port MASTER_PORT
|
||||||
|
Connect_Retry #
|
||||||
Master_Log_File
|
Master_Log_File
|
||||||
Read_Master_Log_Pos 4
|
Read_Master_Log_Pos 4
|
||||||
|
Relay_Log_File #
|
||||||
|
Relay_Log_Pos #
|
||||||
Relay_Master_Log_File
|
Relay_Master_Log_File
|
||||||
|
Slave_IO_Running No
|
||||||
|
Slave_SQL_Running No
|
||||||
|
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 0
|
Exec_Master_Log_Pos 0
|
||||||
|
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
|
||||||
change master to master_host='127.0.0.1',master_user='root',
|
change master to master_host='127.0.0.1',master_user='root',
|
||||||
master_password='',master_port=MASTER_PORT;
|
master_password='',master_port=MASTER_PORT;
|
||||||
|
show slave status;
|
||||||
|
Slave_IO_State #
|
||||||
|
Master_Host 127.0.0.1
|
||||||
|
Master_User root
|
||||||
|
Master_Port MASTER_PORT
|
||||||
|
Connect_Retry #
|
||||||
Master_Log_File
|
Master_Log_File
|
||||||
Read_Master_Log_Pos 4
|
Read_Master_Log_Pos 4
|
||||||
|
Relay_Log_File #
|
||||||
|
Relay_Log_Pos #
|
||||||
Relay_Master_Log_File
|
Relay_Master_Log_File
|
||||||
|
Slave_IO_Running No
|
||||||
|
Slave_SQL_Running No
|
||||||
|
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 0
|
Exec_Master_Log_Pos 0
|
||||||
|
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
|
||||||
start slave;
|
start slave;
|
||||||
|
show slave status;
|
||||||
|
Slave_IO_State Waiting for master to send event
|
||||||
|
Master_Host 127.0.0.1
|
||||||
|
Master_User root
|
||||||
|
Master_Port MASTER_PORT
|
||||||
|
Connect_Retry 1
|
||||||
Master_Log_File master-bin.000001
|
Master_Log_File master-bin.000001
|
||||||
|
Read_Master_Log_Pos 106
|
||||||
|
Relay_Log_File slave-relay-bin.000002
|
||||||
|
Relay_Log_Pos 252
|
||||||
Relay_Master_Log_File master-bin.000001
|
Relay_Master_Log_File master-bin.000001
|
||||||
Checking that both slave threads are running.
|
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 106
|
||||||
|
Relay_Log_Space 407
|
||||||
|
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
|
||||||
drop table if exists t1;
|
drop table if exists t1;
|
||||||
create table t1 (n int, PRIMARY KEY(n));
|
create table t1 (n int, PRIMARY KEY(n));
|
||||||
insert into t1 values (10),(45),(90);
|
insert into t1 values (10),(45),(90);
|
||||||
|
@ -4,7 +4,8 @@ reset master;
|
|||||||
reset slave;
|
reset slave;
|
||||||
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
|
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
|
||||||
start slave;
|
start slave;
|
||||||
SHOW SLAVE STATUS;;
|
SHOW SLAVE STATUS;
|
||||||
|
Slave_IO_State Master_Host Master_User Master_Port Connect_Retry Master_Log_File Read_Master_Log_Pos Relay_Log_File Relay_Log_Pos Relay_Master_Log_File Slave_IO_Running Slave_SQL_Running Replicate_Do_DB Replicate_Ignore_DB Replicate_Do_Table Replicate_Ignore_Table Replicate_Wild_Do_Table Replicate_Wild_Ignore_Table Last_Errno Last_Error Skip_Counter Exec_Master_Log_Pos Relay_Log_Space Until_Condition Until_Log_File Until_Log_Pos Master_SSL_Allowed 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 Last_IO_Errno Last_IO_Error Last_SQL_Errno Last_SQL_Error
|
||||||
SHOW SLAVE HOSTS;
|
SHOW SLAVE HOSTS;
|
||||||
Server_id Host Port Rpl_recovery_rank Master_id
|
Server_id Host Port Rpl_recovery_rank Master_id
|
||||||
2 127.0.0.1 SLAVE_PORT 0 1
|
2 127.0.0.1 SLAVE_PORT 0 1
|
||||||
|
@ -11,7 +11,13 @@ stop slave sql_thread;
|
|||||||
insert into t1 values(1);
|
insert into t1 values(1);
|
||||||
insert into t1 values(2);
|
insert into t1 values(2);
|
||||||
stop slave;
|
stop slave;
|
||||||
|
show slave status;
|
||||||
|
Slave_IO_State Master_Host Master_User Master_Port Connect_Retry Master_Log_File Read_Master_Log_Pos Relay_Log_File Relay_Log_Pos Relay_Master_Log_File Slave_IO_Running Slave_SQL_Running Replicate_Do_DB Replicate_Ignore_DB Replicate_Do_Table Replicate_Ignore_Table Replicate_Wild_Do_Table Replicate_Wild_Ignore_Table Last_Errno Last_Error Skip_Counter Exec_Master_Log_Pos Relay_Log_Space Until_Condition Until_Log_File Until_Log_Pos Master_SSL_Allowed 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 Last_IO_Errno Last_IO_Error Last_SQL_Errno Last_SQL_Error
|
||||||
|
# 127.0.0.1 root MASTER_MYPORT 1 master-bin.000001 # # # master-bin.000001 No No 0 0 191 # None 0 No # No 0 0
|
||||||
change master to master_user='root';
|
change master to master_user='root';
|
||||||
|
show slave status;
|
||||||
|
Slave_IO_State Master_Host Master_User Master_Port Connect_Retry Master_Log_File Read_Master_Log_Pos Relay_Log_File Relay_Log_Pos Relay_Master_Log_File Slave_IO_Running Slave_SQL_Running Replicate_Do_DB Replicate_Ignore_DB Replicate_Do_Table Replicate_Ignore_Table Replicate_Wild_Do_Table Replicate_Wild_Ignore_Table Last_Errno Last_Error Skip_Counter Exec_Master_Log_Pos Relay_Log_Space Until_Condition Until_Log_File Until_Log_Pos Master_SSL_Allowed 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 Last_IO_Errno Last_IO_Error Last_SQL_Errno Last_SQL_Error
|
||||||
|
# 127.0.0.1 root MASTER_MYPORT 1 master-bin.000001 # # # master-bin.000001 No No 0 0 191 # None 0 No # No 0 0
|
||||||
start slave;
|
start slave;
|
||||||
select * from t1;
|
select * from t1;
|
||||||
n
|
n
|
||||||
|
@ -4,6 +4,8 @@ reset master;
|
|||||||
reset slave;
|
reset slave;
|
||||||
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
|
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
|
||||||
start slave;
|
start slave;
|
||||||
|
show slave status;
|
||||||
|
Slave_IO_State Master_Host Master_User Master_Port Connect_Retry Master_Log_File Read_Master_Log_Pos Relay_Log_File Relay_Log_Pos Relay_Master_Log_File Slave_IO_Running Slave_SQL_Running Replicate_Do_DB Replicate_Ignore_DB Replicate_Do_Table Replicate_Ignore_Table Replicate_Wild_Do_Table Replicate_Wild_Ignore_Table Last_Errno Last_Error Skip_Counter Exec_Master_Log_Pos Relay_Log_Space Until_Condition Until_Log_File Until_Log_Pos Master_SSL_Allowed 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 Last_IO_Errno Last_IO_Error Last_SQL_Errno Last_SQL_Error
|
||||||
load table t1 from master;
|
load table t1 from master;
|
||||||
ERROR 08S01: Error connecting to master: Master is not configured
|
ERROR 08S01: Error connecting to master: Master is not configured
|
||||||
load table t1 from master;
|
load table t1 from master;
|
||||||
|
@ -17,6 +17,43 @@ let $result_pattern= '%127.0.0.1%root%slave-bin.000001%slave-bin.000001%Yes%Yes%
|
|||||||
|
|
||||||
--source include/wait_slave_status.inc
|
--source include/wait_slave_status.inc
|
||||||
flush logs;
|
flush logs;
|
||||||
Relay_Log_File mysqld-relay-bin.000003
|
SHOW SLAVE STATUS;
|
||||||
Checking that both slave threads are running.
|
Slave_IO_State #
|
||||||
|
Master_Host 127.0.0.1
|
||||||
|
Master_User root
|
||||||
|
Master_Port SLAVE_PORT
|
||||||
|
Connect_Retry 60
|
||||||
|
Master_Log_File slave-bin.000001
|
||||||
|
Read_Master_Log_Pos 106
|
||||||
|
Relay_Log_File #
|
||||||
|
Relay_Log_Pos #
|
||||||
|
Relay_Master_Log_File slave-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 106
|
||||||
|
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
|
||||||
STOP SLAVE;
|
STOP SLAVE;
|
||||||
|
@ -10,6 +10,6 @@ load data infile '../../std_data/rpl_loaddata.dat' into table test.t1;
|
|||||||
select count(*) from test.t1;
|
select count(*) from test.t1;
|
||||||
count(*)
|
count(*)
|
||||||
2
|
2
|
||||||
show binlog events from <binlog_start>;
|
show binlog events from 106;
|
||||||
Log_name Pos Event_type Server_id End_log_pos Info
|
Log_name Pos Event_type Server_id End_log_pos Info
|
||||||
drop table test.t1;
|
drop table test.t1;
|
||||||
|
@ -4,23 +4,39 @@ reset master;
|
|||||||
reset slave;
|
reset slave;
|
||||||
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
|
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
|
||||||
start slave;
|
start slave;
|
||||||
|
show master status;
|
||||||
|
File Position Binlog_Do_DB Binlog_Ignore_DB
|
||||||
|
master-bin.000001 106 <Binlog_Ignore_DB>
|
||||||
|
show slave status;
|
||||||
|
Slave_IO_State Master_Host Master_User Master_Port Connect_Retry Master_Log_File Read_Master_Log_Pos Relay_Log_File Relay_Log_Pos Relay_Master_Log_File Slave_IO_Running Slave_SQL_Running Replicate_Do_DB Replicate_Ignore_DB Replicate_Do_Table Replicate_Ignore_Table Replicate_Wild_Do_Table Replicate_Wild_Ignore_Table Last_Errno Last_Error Skip_Counter Exec_Master_Log_Pos Relay_Log_Space Until_Condition Until_Log_File Until_Log_Pos Master_SSL_Allowed 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 Last_IO_Errno Last_IO_Error Last_SQL_Errno Last_SQL_Error
|
||||||
|
# 127.0.0.1 root MASTER_PORT 1 master-bin.000001 106 # # master-bin.000001 Yes Yes 0 0 106 # None 0 No # No 0 0
|
||||||
stop slave;
|
stop slave;
|
||||||
change master to master_log_pos=MASTER_LOG_POS;
|
change master to master_log_pos=106;
|
||||||
start slave;
|
start slave;
|
||||||
stop slave;
|
stop slave;
|
||||||
change master to master_log_pos=MASTER_LOG_POS;
|
change master to master_log_pos=106;
|
||||||
|
show slave status;
|
||||||
|
Slave_IO_State Master_Host Master_User Master_Port Connect_Retry Master_Log_File Read_Master_Log_Pos Relay_Log_File Relay_Log_Pos Relay_Master_Log_File Slave_IO_Running Slave_SQL_Running Replicate_Do_DB Replicate_Ignore_DB Replicate_Do_Table Replicate_Ignore_Table Replicate_Wild_Do_Table Replicate_Wild_Ignore_Table Last_Errno Last_Error Skip_Counter Exec_Master_Log_Pos Relay_Log_Space Until_Condition Until_Log_File Until_Log_Pos Master_SSL_Allowed 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 Last_IO_Errno Last_IO_Error Last_SQL_Errno Last_SQL_Error
|
||||||
|
# 127.0.0.1 root MASTER_PORT 1 master-bin.000001 106 # # master-bin.000001 No No 0 0 106 # None 0 No # No 0 0
|
||||||
start slave;
|
start slave;
|
||||||
|
show slave status;
|
||||||
|
Slave_IO_State Master_Host Master_User Master_Port Connect_Retry Master_Log_File Read_Master_Log_Pos Relay_Log_File Relay_Log_Pos Relay_Master_Log_File Slave_IO_Running Slave_SQL_Running Replicate_Do_DB Replicate_Ignore_DB Replicate_Do_Table Replicate_Ignore_Table Replicate_Wild_Do_Table Replicate_Wild_Ignore_Table Last_Errno Last_Error Skip_Counter Exec_Master_Log_Pos Relay_Log_Space Until_Condition Until_Log_File Until_Log_Pos Master_SSL_Allowed 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 Last_IO_Errno Last_IO_Error Last_SQL_Errno Last_SQL_Error
|
||||||
|
# 127.0.0.1 root MASTER_PORT 1 master-bin.000001 106 # # master-bin.000001 Yes Yes 0 0 106 # None 0 No # No 0 0
|
||||||
stop slave;
|
stop slave;
|
||||||
# impossible position leads to an error
|
change master to master_log_pos=177;
|
||||||
change master to master_log_pos=MASTER_LOG_POS;
|
|
||||||
start slave;
|
start slave;
|
||||||
Last_IO_Error = Got fatal error 1236 from master when reading data from binary log: 'Client requested master to start replication from impossible position'
|
show slave status;
|
||||||
|
Slave_IO_State Master_Host Master_User Master_Port Connect_Retry Master_Log_File Read_Master_Log_Pos Relay_Log_File Relay_Log_Pos Relay_Master_Log_File Slave_IO_Running Slave_SQL_Running Replicate_Do_DB Replicate_Ignore_DB Replicate_Do_Table Replicate_Ignore_Table Replicate_Wild_Do_Table Replicate_Wild_Ignore_Table Last_Errno Last_Error Skip_Counter Exec_Master_Log_Pos Relay_Log_Space Until_Condition Until_Log_File Until_Log_Pos Master_SSL_Allowed 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 Last_IO_Errno Last_IO_Error Last_SQL_Errno Last_SQL_Error
|
||||||
|
# 127.0.0.1 root MASTER_PORT 1 master-bin.000001 177 # # master-bin.000001 No Yes 0 0 177 # None 0 No # No 1236 Got fatal error 1236 from master when reading data from binary log: 'Client requested master to start replication from impossible position' 0
|
||||||
|
show master status;
|
||||||
|
File Position Binlog_Do_DB Binlog_Ignore_DB
|
||||||
|
master-bin.000001 106 <Binlog_Ignore_DB>
|
||||||
create table if not exists t1 (n int);
|
create table if not exists t1 (n int);
|
||||||
drop table if exists t1;
|
drop table if exists t1;
|
||||||
create table t1 (n int);
|
create table t1 (n int);
|
||||||
insert into t1 values (1),(2),(3);
|
insert into t1 values (1),(2),(3);
|
||||||
stop slave;
|
stop slave;
|
||||||
change master to master_log_pos=MASTER_LOG_POS;
|
change master to master_log_pos=206;
|
||||||
start slave;
|
start slave;
|
||||||
select * from t1 ORDER BY n;
|
select * from t1 ORDER BY n;
|
||||||
n
|
n
|
||||||
|
@ -14,16 +14,47 @@ MIXED MIXED
|
|||||||
CREATE TABLE t1 (a INT, b LONG);
|
CREATE TABLE t1 (a INT, b LONG);
|
||||||
INSERT INTO t1 VALUES (1,1), (2,2);
|
INSERT INTO t1 VALUES (1,1), (2,2);
|
||||||
INSERT INTO t1 VALUES (3,UUID()), (4,UUID());
|
INSERT INTO t1 VALUES (3,UUID()), (4,UUID());
|
||||||
show binlog events from <binlog_start>;
|
SHOW BINLOG EVENTS;
|
||||||
**** On Slave ****
|
**** On Slave ****
|
||||||
show binlog events from <binlog_start>;
|
SHOW SLAVE STATUS;
|
||||||
Log_name Pos Event_type Server_id End_log_pos Info
|
Slave_IO_State #
|
||||||
slave-bin.000001 # Query # # use `test`; CREATE TABLE t1 (a INT, b LONG)
|
Master_Host 127.0.0.1
|
||||||
slave-bin.000001 # Query # # use `test`; INSERT INTO t1 VALUES (1,1), (2,2)
|
Master_User root
|
||||||
slave-bin.000001 # Query # # BEGIN
|
Master_Port MASTER_PORT
|
||||||
slave-bin.000001 # Table_map # # table_id: # (test.t1)
|
Connect_Retry 1
|
||||||
slave-bin.000001 # Write_rows # # table_id: # flags: STMT_END_F
|
Master_Log_File master-bin.000001
|
||||||
slave-bin.000001 # Query # # COMMIT
|
Read_Master_Log_Pos #
|
||||||
show binlog events from <binlog_start>;
|
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
|
||||||
|
SHOW BINLOG EVENTS;
|
||||||
DROP TABLE IF EXISTS t1;
|
DROP TABLE IF EXISTS t1;
|
||||||
SET GLOBAL BINLOG_FORMAT=@saved_binlog_format;
|
SET GLOBAL BINLOG_FORMAT=@saved_binlog_format;
|
||||||
|
@ -41,11 +41,12 @@ t1
|
|||||||
t2
|
t2
|
||||||
**** On Master ****
|
**** On Master ****
|
||||||
DROP TABLE t1,t2;
|
DROP TABLE t1,t2;
|
||||||
show binlog events from <binlog_start>;
|
SHOW BINLOG EVENTS;
|
||||||
Log_name Pos Event_type Server_id End_log_pos Info
|
Log_name Pos Event_type Server_id End_log_pos Info
|
||||||
master-bin.000001 # Query # # use `test`; CREATE TABLE t1 (a int)
|
master-bin.000001 4 Format_desc 1 106 Server ver: VERSION, Binlog ver: 4
|
||||||
master-bin.000001 # Query # # use `test`; CREATE TABLE t2 (a int)
|
master-bin.000001 106 Query 1 192 use `test`; CREATE TABLE t1 (a int)
|
||||||
master-bin.000001 # Query # # use `test`; DROP TABLE `t1` /* generated by server */
|
master-bin.000001 192 Query 1 278 use `test`; CREATE TABLE t2 (a int)
|
||||||
|
master-bin.000001 278 Query 1 382 use `test`; DROP TABLE `t1` /* generated by server */
|
||||||
SHOW TABLES;
|
SHOW TABLES;
|
||||||
Tables_in_test
|
Tables_in_test
|
||||||
t2
|
t2
|
||||||
|
@ -17,5 +17,43 @@ a
|
|||||||
0
|
0
|
||||||
drop table t1;
|
drop table t1;
|
||||||
insert into t1 values (1);
|
insert into t1 values (1);
|
||||||
Last_SQL_Error = Error 'Table 'test.t1' doesn't exist' on opening tables
|
show slave status;
|
||||||
|
Slave_IO_State #
|
||||||
|
Master_Host 127.0.0.1
|
||||||
|
Master_User root
|
||||||
|
Master_Port MASTER_MYPORT
|
||||||
|
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 No
|
||||||
|
Replicate_Do_DB
|
||||||
|
Replicate_Ignore_DB
|
||||||
|
Replicate_Do_Table
|
||||||
|
Replicate_Ignore_Table test.t2
|
||||||
|
Replicate_Wild_Do_Table
|
||||||
|
Replicate_Wild_Ignore_Table
|
||||||
|
Last_Errno 1146
|
||||||
|
Last_Error Error 'Table 'test.t1' doesn't exist' on opening tables
|
||||||
|
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 1146
|
||||||
|
Last_SQL_Error Error 'Table 'test.t1' doesn't exist' on opening tables
|
||||||
drop table t1, t2;
|
drop table t1, t2;
|
||||||
|
@ -12,39 +12,193 @@ create table t2(n int not null auto_increment primary key);
|
|||||||
insert into t2 values (1),(2);
|
insert into t2 values (1),(2);
|
||||||
insert into t2 values (3),(4);
|
insert into t2 values (3),(4);
|
||||||
drop table t2;
|
drop table t2;
|
||||||
start slave until master_log_file='master-bin.000001', master_log_pos=MASTER_LOG_POS;
|
start slave until master_log_file='master-bin.000001', master_log_pos=311;
|
||||||
select * from t1;
|
select * from t1;
|
||||||
n
|
n
|
||||||
1
|
1
|
||||||
2
|
2
|
||||||
3
|
3
|
||||||
4
|
4
|
||||||
start slave until master_log_file='master-no-such-bin.000001', master_log_pos=MASTER_LOG_POS;
|
show slave status;
|
||||||
|
Slave_IO_State #
|
||||||
|
Master_Host 127.0.0.1
|
||||||
|
Master_User root
|
||||||
|
Master_Port MASTER_MYPORT
|
||||||
|
Connect_Retry 1
|
||||||
|
Master_Log_File master-bin.000001
|
||||||
|
Read_Master_Log_Pos #
|
||||||
|
Relay_Log_File slave-relay-bin.000004
|
||||||
|
Relay_Log_Pos #
|
||||||
|
Relay_Master_Log_File master-bin.000001
|
||||||
|
Slave_IO_Running #
|
||||||
|
Slave_SQL_Running No
|
||||||
|
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 Master
|
||||||
|
Until_Log_File master-bin.000001
|
||||||
|
Until_Log_Pos 311
|
||||||
|
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
|
||||||
|
start slave until master_log_file='master-no-such-bin.000001', master_log_pos=291;
|
||||||
select * from t1;
|
select * from t1;
|
||||||
n
|
n 1
|
||||||
1
|
n 2
|
||||||
2
|
n 3
|
||||||
3
|
n 4
|
||||||
4
|
show slave status;
|
||||||
start slave until relay_log_file='slave-relay-bin.000004', relay_log_pos=RELAY_LOG_POS;
|
Slave_IO_State #
|
||||||
|
Master_Host 127.0.0.1
|
||||||
|
Master_User root
|
||||||
|
Master_Port MASTER_MYPORT
|
||||||
|
Connect_Retry 1
|
||||||
|
Master_Log_File master-bin.000001
|
||||||
|
Read_Master_Log_Pos #
|
||||||
|
Relay_Log_File slave-relay-bin.000004
|
||||||
|
Relay_Log_Pos #
|
||||||
|
Relay_Master_Log_File master-bin.000001
|
||||||
|
Slave_IO_Running #
|
||||||
|
Slave_SQL_Running No
|
||||||
|
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 Master
|
||||||
|
Until_Log_File master-no-such-bin.000001
|
||||||
|
Until_Log_Pos 291
|
||||||
|
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
|
||||||
|
start slave until relay_log_file='slave-relay-bin.000004', relay_log_pos=728;
|
||||||
select * from t2;
|
select * from t2;
|
||||||
n
|
show slave status;
|
||||||
1
|
Slave_IO_State #
|
||||||
2
|
Master_Host 127.0.0.1
|
||||||
|
Master_User root
|
||||||
|
Master_Port MASTER_MYPORT
|
||||||
|
Connect_Retry 1
|
||||||
|
Master_Log_File master-bin.000001
|
||||||
|
Read_Master_Log_Pos #
|
||||||
|
Relay_Log_File slave-relay-bin.000004
|
||||||
|
Relay_Log_Pos #
|
||||||
|
Relay_Master_Log_File master-bin.000001
|
||||||
|
Slave_IO_Running #
|
||||||
|
Slave_SQL_Running No
|
||||||
|
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 Relay
|
||||||
|
Until_Log_File slave-relay-bin.000004
|
||||||
|
Until_Log_Pos 728
|
||||||
|
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
|
||||||
start slave;
|
start slave;
|
||||||
stop slave;
|
stop slave;
|
||||||
start slave until master_log_file='master-bin.000001', master_log_pos=MASTER_LOG_POS;
|
start slave until master_log_file='master-bin.000001', master_log_pos=740;
|
||||||
start slave until master_log_file='master-bin', master_log_pos=MASTER_LOG_POS;
|
show slave status;
|
||||||
|
Slave_IO_State #
|
||||||
|
Master_Host 127.0.0.1
|
||||||
|
Master_User root
|
||||||
|
Master_Port MASTER_MYPORT
|
||||||
|
Connect_Retry 1
|
||||||
|
Master_Log_File master-bin.000001
|
||||||
|
Read_Master_Log_Pos #
|
||||||
|
Relay_Log_File slave-relay-bin.000004
|
||||||
|
Relay_Log_Pos #
|
||||||
|
Relay_Master_Log_File master-bin.000001
|
||||||
|
Slave_IO_Running Yes
|
||||||
|
Slave_SQL_Running No
|
||||||
|
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 Master
|
||||||
|
Until_Log_File master-bin.000001
|
||||||
|
Until_Log_Pos 740
|
||||||
|
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
|
||||||
|
start slave until master_log_file='master-bin', master_log_pos=561;
|
||||||
ERROR HY000: Incorrect parameter or combination of parameters for START SLAVE UNTIL
|
ERROR HY000: Incorrect parameter or combination of parameters for START SLAVE UNTIL
|
||||||
start slave until master_log_file='master-bin.000001', master_log_pos=MASTER_LOG_POS, relay_log_pos=RELAY_LOG_POS;
|
start slave until master_log_file='master-bin.000001', master_log_pos=561, relay_log_pos=12;
|
||||||
ERROR HY000: Incorrect parameter or combination of parameters for START SLAVE UNTIL
|
ERROR HY000: Incorrect parameter or combination of parameters for START SLAVE UNTIL
|
||||||
start slave until master_log_file='master-bin.000001';
|
start slave until master_log_file='master-bin.000001';
|
||||||
ERROR HY000: Incorrect parameter or combination of parameters for START SLAVE UNTIL
|
ERROR HY000: Incorrect parameter or combination of parameters for START SLAVE UNTIL
|
||||||
start slave until relay_log_file='slave-relay-bin.000002';
|
start slave until relay_log_file='slave-relay-bin.000002';
|
||||||
ERROR HY000: Incorrect parameter or combination of parameters for START SLAVE UNTIL
|
ERROR HY000: Incorrect parameter or combination of parameters for START SLAVE UNTIL
|
||||||
start slave until relay_log_file='slave-relay-bin.000002', master_log_pos=MASTER_LOG_POS;
|
start slave until relay_log_file='slave-relay-bin.000002', master_log_pos=561;
|
||||||
ERROR HY000: Incorrect parameter or combination of parameters for START SLAVE UNTIL
|
ERROR HY000: Incorrect parameter or combination of parameters for START SLAVE UNTIL
|
||||||
start slave sql_thread;
|
start slave sql_thread;
|
||||||
start slave until master_log_file='master-bin.000001', master_log_pos=MASTER_LOG_POS;
|
start slave until master_log_file='master-bin.000001', master_log_pos=740;
|
||||||
Warnings:
|
Warnings:
|
||||||
Note 1254 Slave is already running
|
Level Note
|
||||||
|
Code 1254
|
||||||
|
Message Slave is already running
|
||||||
|
@ -8,8 +8,10 @@ create table t1 (n int);
|
|||||||
reset master;
|
reset master;
|
||||||
stop slave;
|
stop slave;
|
||||||
change master to master_port=SLAVE_PORT;
|
change master to master_port=SLAVE_PORT;
|
||||||
|
show slave status;
|
||||||
|
Slave_IO_State Master_Host Master_User Master_Port Connect_Retry Master_Log_File Read_Master_Log_Pos Relay_Log_File Relay_Log_Pos Relay_Master_Log_File Slave_IO_Running Slave_SQL_Running Replicate_Do_DB Replicate_Ignore_DB Replicate_Do_Table Replicate_Ignore_Table Replicate_Wild_Do_Table Replicate_Wild_Ignore_Table Last_Errno Last_Error Skip_Counter Exec_Master_Log_Pos Relay_Log_Space Until_Condition Until_Log_File Until_Log_Pos Master_SSL_Allowed 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 Last_IO_Errno Last_IO_Error Last_SQL_Errno Last_SQL_Error
|
||||||
|
127.0.0.1 root SLAVE_PORT 1 4 slave-relay-bin.000001 4 No No # # 0 0 0 106 None 0 No NULL No 0 0
|
||||||
start slave;
|
start slave;
|
||||||
Last_IO_Error = Fatal error: The slave I/O thread stops because master and slave have equal MySQL server ids; these ids must be different for replication to work (or the --replicate-same-server-id option must be used on slave but this does not always make sense; please check the manual before using it).
|
|
||||||
insert into t1 values (1);
|
insert into t1 values (1);
|
||||||
show status like "slave_running";
|
show status like "slave_running";
|
||||||
Variable_name Value
|
Variable_name Value
|
||||||
|
@ -8,6 +8,9 @@ create table t1 (n int);
|
|||||||
reset master;
|
reset master;
|
||||||
stop slave;
|
stop slave;
|
||||||
change master to master_port=SLAVE_PORT;
|
change master to master_port=SLAVE_PORT;
|
||||||
|
show slave status;
|
||||||
|
Slave_IO_State Master_Host Master_User Master_Port Connect_Retry Master_Log_File Read_Master_Log_Pos Relay_Log_File Relay_Log_Pos Relay_Master_Log_File Slave_IO_Running Slave_SQL_Running Replicate_Do_DB Replicate_Ignore_DB Replicate_Do_Table Replicate_Ignore_Table Replicate_Wild_Do_Table Replicate_Wild_Ignore_Table Last_Errno Last_Error Skip_Counter Exec_Master_Log_Pos Relay_Log_Space Until_Condition Until_Log_File Until_Log_Pos Master_SSL_Allowed 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 Last_IO_Errno Last_IO_Error Last_SQL_Errno Last_SQL_Error
|
||||||
|
127.0.0.1 root SLAVE_PORT 1 4 slave-relay-bin.000001 4 No No # 0 0 0 106 None 0 No NULL No 0 0
|
||||||
start slave;
|
start slave;
|
||||||
insert into t1 values (1);
|
insert into t1 values (1);
|
||||||
select * from t1;
|
select * from t1;
|
||||||
|
@ -18,5 +18,44 @@ drop user rpl@127.0.0.1;
|
|||||||
flush privileges;
|
flush privileges;
|
||||||
stop slave;
|
stop slave;
|
||||||
start slave;
|
start slave;
|
||||||
|
show slave status;
|
||||||
|
Slave_IO_State #
|
||||||
|
Master_Host 127.0.0.1
|
||||||
|
Master_User rpl
|
||||||
|
Master_Port MASTER_MYPORT
|
||||||
|
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 No
|
||||||
|
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 NULL
|
||||||
|
Master_SSL_Verify_Server_Cert No
|
||||||
|
Last_IO_Errno #
|
||||||
|
Last_IO_Error #
|
||||||
|
Last_SQL_Errno 0
|
||||||
|
Last_SQL_Error
|
||||||
drop table t1;
|
drop table t1;
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
@ -176,7 +176,7 @@ end|
|
|||||||
ERROR HY000: You do not have the SUPER privilege and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creators variable)
|
ERROR HY000: You do not have the SUPER privilege and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creators variable)
|
||||||
set global log_bin_trust_routine_creators=1;
|
set global log_bin_trust_routine_creators=1;
|
||||||
Warnings:
|
Warnings:
|
||||||
Warning 1287 The syntax '@@log_bin_trust_routine_creators' is deprecated and will be removed in MySQL 5.6. Please use '@@log_bin_trust_function_creators' instead
|
Warning 1287 '@@log_bin_trust_routine_creators' is deprecated and will be removed in a future release. Please use '@@log_bin_trust_function_creators' instead
|
||||||
set global log_bin_trust_function_creators=0;
|
set global log_bin_trust_function_creators=0;
|
||||||
set global log_bin_trust_function_creators=1;
|
set global log_bin_trust_function_creators=1;
|
||||||
set global log_bin_trust_function_creators=1;
|
set global log_bin_trust_function_creators=1;
|
||||||
|
@ -376,7 +376,7 @@ CREATE TABLE t12 (data LONG);
|
|||||||
LOCK TABLES t12 WRITE;
|
LOCK TABLES t12 WRITE;
|
||||||
INSERT INTO t12 VALUES(UUID());
|
INSERT INTO t12 VALUES(UUID());
|
||||||
UNLOCK TABLES;
|
UNLOCK TABLES;
|
||||||
show binlog events from <binlog_start>;
|
show binlog events;
|
||||||
show binlog events from <binlog_start>;
|
show binlog events;
|
||||||
drop database mysqltest1;
|
drop database mysqltest1;
|
||||||
set global binlog_format= @saved_binlog_format;
|
set global binlog_format= @saved_binlog_format;
|
||||||
|
@ -5,3 +5,92 @@ crash_manycolumns_string : Bug#50495 'Row size too large' for plugin, but works
|
|||||||
ix_unique_lob : Bug#52283 Innodb reports extra warnings when SELECT/WHERE is performed using invalid value
|
ix_unique_lob : Bug#52283 Innodb reports extra warnings when SELECT/WHERE is performed using invalid value
|
||||||
ix_unique_string_length : Bug#52283 Innodb reports extra warnings when SELECT/WHERE is performed using invalid value
|
ix_unique_string_length : Bug#52283 Innodb reports extra warnings when SELECT/WHERE is performed using invalid value
|
||||||
|
|
||||||
|
rpl_create_database : Result Difference Due to Change in .inc file
|
||||||
|
rpl_loaddata_m : Result Difference Due to Change in .inc file
|
||||||
|
rpl_sp_effects : Result Difference Due to Change in .inc file
|
||||||
|
rpl_variables : Result Difference Due to Change in .inc file
|
||||||
|
rpl_loaddata_s : Result Difference Due to Change in .inc file
|
||||||
|
rpl_server_id2 : Result Difference Due to Change in .inc file
|
||||||
|
rpl000010 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_init_slave : Result Difference Due to Change in .inc file
|
||||||
|
rpl_dual_pos_advance : Result Difference Due to Change in .inc file
|
||||||
|
rpl_empty_master_crash : Result Difference Due to Change in .inc file
|
||||||
|
rpl000011 : Result Difference Due to Change in .inc file
|
||||||
|
rpl000013 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_000015 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_LD_INFILE : Result Difference Due to Change in .inc file
|
||||||
|
rpl_REDIRECT : Result Difference Due to Change in .inc file
|
||||||
|
rpl_alter : Result Difference Due to Change in .inc file
|
||||||
|
rpl_alter_db : Result Difference Due to Change in .inc file
|
||||||
|
rpl_bit : Result Difference Due to Change in .inc file
|
||||||
|
rpl_bit_npk : Result Difference Due to Change in .inc file
|
||||||
|
rpl_change_master : Result Difference Due to Change in .inc file
|
||||||
|
rpl_do_grant : Result Difference Due to Change in .inc file
|
||||||
|
rpl_drop : Result Difference Due to Change in .inc file
|
||||||
|
rpl_drop_db : Result Difference Due to Change in .inc file
|
||||||
|
rpl_flushlog_loop : Result Difference Due to Change in .inc file
|
||||||
|
rpl_get_lock : Result Difference Due to Change in .inc file
|
||||||
|
rpl_insert : Result Difference Due to Change in .inc file
|
||||||
|
rpl_insert_select : Result Difference Due to Change in .inc file
|
||||||
|
rpl_loaddata2 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_loaddatalocal : Result Difference Due to Change in .inc file
|
||||||
|
rpl_loadfile : Result Difference Due to Change in .inc file
|
||||||
|
rpl_log_pos : Result Difference Due to Change in .inc file
|
||||||
|
rpl_many_optimize : Result Difference Due to Change in .inc file
|
||||||
|
rpl_master_pos_wait : Result Difference Due to Change in .inc file
|
||||||
|
rpl_misc_functions : Result Difference Due to Change in .inc file
|
||||||
|
rpl_ps : Result Difference Due to Change in .inc file
|
||||||
|
rpl_rbr_to_sbr : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_max_relay_size : Result Difference Due to Change in .inc file
|
||||||
|
rpl_server_id1 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_session_var : Result Difference Due to Change in .inc file
|
||||||
|
rpl_sf : Result Difference Due to Change in .inc file
|
||||||
|
rpl_slave_status : Result Difference Due to Change in .inc file
|
||||||
|
rpl_sp004 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_start_stop_slave : Result Difference Due to Change in .inc file
|
||||||
|
rpl_stm_max_relay_size : Result Difference Due to Change in .inc file
|
||||||
|
rpl_stm_mystery22 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_stm_no_op : Result Difference Due to Change in .inc file
|
||||||
|
rpl_stm_reset_slave : Result Difference Due to Change in .inc file
|
||||||
|
rpl_temp_table : Result Difference Due to Change in .inc file
|
||||||
|
rpl_temporary : Result Difference Due to Change in .inc file
|
||||||
|
rpl_trigger : Result Difference Due to Change in .inc file
|
||||||
|
rpl_trunc_temp : Result Difference Due to Change in .inc file
|
||||||
|
rpl_user_variables : Result Difference Due to Change in .inc file
|
||||||
|
rpl_relayspace : Result Difference Due to Change in .inc file
|
||||||
|
rpl_multi_delete2 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_view : Result Difference Due to Change in .inc file
|
||||||
|
rpl_ignore_table_update : Result Difference Due to Change in .inc file
|
||||||
|
rpl_err_ignoredtable : Result Difference Due to Change in .inc file
|
||||||
|
rpl_multi_update4 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_multi_delete : Result Difference Due to Change in .inc file
|
||||||
|
rpl_ignore_grant : Result Difference Due to Change in .inc file
|
||||||
|
rpl_ignore_revoke : Result Difference Due to Change in .inc file
|
||||||
|
rpl_free_items : Result Difference Due to Change in .inc file
|
||||||
|
rpl_replicate_ignore_db : Result Difference Due to Change in .inc file
|
||||||
|
rpl000017 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_skip_error : Result Difference Due to Change in .inc file
|
||||||
|
rpl_sp : Result Difference Due to Change in .inc file
|
||||||
|
|
||||||
|
rpl_row_until : Test Present in rpl suite as well . Test Fails with table t2 not found.
|
||||||
|
rpl_loaddata_s : Test Present in rpl suite as well . Test Fails due to bin log truncation.
|
||||||
|
rpl_log_pos : Test Present in rpl suite as well . Test Fails due to bin log truncation.
|
||||||
|
rpl_row_NOW : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_USER : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_drop : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_func001 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_reset_slave : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_sp001 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_sp005 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_sp008 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_sp009 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_sp010 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_sp011 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_sp012 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_stop_middle : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_trig001 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_trig002 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_trig003 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_view01 : Result Difference Due to Change in .inc file
|
||||||
|
rpl_switch_stm_row_mixed : Result Difference Due to Change in .inc file
|
||||||
|
rpl_row_inexist_tbl : Result Difference Due to Change in .inc file
|
||||||
|
@ -11,25 +11,31 @@ save_master_pos;
|
|||||||
connection slave;
|
connection slave;
|
||||||
stop slave;
|
stop slave;
|
||||||
reset slave;
|
reset slave;
|
||||||
let $status_items= Master_Log_File, Read_Master_Log_Pos, Relay_Master_Log_File, Exec_Master_Log_Pos;
|
--vertical_results
|
||||||
source include/show_slave_status.inc;
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
||||||
|
--replace_column 1 # 5 # 8 # 9 # 23 # 33 #
|
||||||
|
show slave status;
|
||||||
|
|
||||||
change master to master_host='127.0.0.1';
|
change master to master_host='127.0.0.1';
|
||||||
# The following needs to be cleaned up when change master is fixed
|
# The following needs to be cleaned up when change master is fixed
|
||||||
source include/show_slave_status.inc;
|
--vertical_results
|
||||||
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
||||||
|
--replace_column 1 # 5 # 8 # 9 # 23 # 33 #
|
||||||
|
show slave status;
|
||||||
--replace_result $MASTER_MYPORT MASTER_PORT
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
||||||
eval change master to master_host='127.0.0.1',master_user='root',
|
eval change master to master_host='127.0.0.1',master_user='root',
|
||||||
master_password='',master_port=$MASTER_MYPORT;
|
master_password='',master_port=$MASTER_MYPORT;
|
||||||
source include/show_slave_status.inc;
|
--vertical_results
|
||||||
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
||||||
|
--replace_column 1 # 5 # 8 # 9 # 23 # 33 #
|
||||||
|
show slave status;
|
||||||
start slave;
|
start slave;
|
||||||
sync_with_master;
|
sync_with_master;
|
||||||
let $status_items= Master_Log_File, Relay_Master_Log_File;
|
|
||||||
source include/show_slave_status.inc;
|
|
||||||
source include/check_slave_is_running.inc;
|
|
||||||
|
|
||||||
--vertical_results
|
--vertical_results
|
||||||
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
||||||
|
--replace_column 1 # 5 # 8 # 9 # 23 # 33 #
|
||||||
|
--replace_column 33 #
|
||||||
|
show slave status;
|
||||||
connection master;
|
connection master;
|
||||||
--disable_warnings
|
--disable_warnings
|
||||||
drop table if exists t1;
|
drop table if exists t1;
|
||||||
|
@ -7,11 +7,15 @@ source include/master-slave.inc;
|
|||||||
--disable_ps_protocol
|
--disable_ps_protocol
|
||||||
|
|
||||||
#first, make sure the slave has had enough time to register
|
#first, make sure the slave has had enough time to register
|
||||||
sync_slave_with_master;
|
save_master_pos;
|
||||||
|
connection slave;
|
||||||
|
sync_with_master;
|
||||||
|
|
||||||
#discover slaves
|
#discover slaves
|
||||||
connection master;
|
connection master;
|
||||||
--query_vertical SHOW SLAVE STATUS;
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
||||||
|
--replace_column 1 # 8 # 9 # 16 # 23 # 33 #
|
||||||
|
SHOW SLAVE STATUS;
|
||||||
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
||||||
SHOW SLAVE HOSTS;
|
SHOW SLAVE HOSTS;
|
||||||
rpl_probe;
|
rpl_probe;
|
||||||
@ -21,7 +25,9 @@ enable_rpl_parse;
|
|||||||
create table t1 ( n int);
|
create table t1 ( n int);
|
||||||
insert into t1 values (1),(2),(3),(4);
|
insert into t1 values (1),(2),(3),(4);
|
||||||
disable_rpl_parse;
|
disable_rpl_parse;
|
||||||
sync_slave_with_master;
|
save_master_pos;
|
||||||
|
connection slave;
|
||||||
|
sync_with_master;
|
||||||
insert into t1 values(5);
|
insert into t1 values(5);
|
||||||
connection master;
|
connection master;
|
||||||
enable_rpl_parse;
|
enable_rpl_parse;
|
||||||
|
@ -18,26 +18,13 @@ save_master_pos;
|
|||||||
connection slave;
|
connection slave;
|
||||||
--real_sleep 3 # wait for I/O thread to have read updates
|
--real_sleep 3 # wait for I/O thread to have read updates
|
||||||
stop slave;
|
stop slave;
|
||||||
source include/wait_for_slave_to_stop.inc;
|
--replace_result $MASTER_MYPORT MASTER_MYPORT
|
||||||
|
--replace_column 1 # 7 # 8 # 9 # 23 # 33 #
|
||||||
let $read_pos= query_get_value(SHOW SLAVE STATUS, Read_Master_Log_Pos, 1);
|
show slave status;
|
||||||
let $exec_pos= query_get_value(SHOW SLAVE STATUS, Exec_Master_Log_Pos, 1);
|
|
||||||
if (`SELECT $read_pos = $exec_pos`)
|
|
||||||
{
|
|
||||||
source include/show_rpl_debug_info.inc;
|
|
||||||
echo 'Read_Master_Log_Pos: $read_pos' == 'Exec_Master_Log_Pos: $exec_pos';
|
|
||||||
die Failed because Read_Master_Log_Pos is equal to Exec_Master_Log_Pos;
|
|
||||||
}
|
|
||||||
change master to master_user='root';
|
change master to master_user='root';
|
||||||
let $read_pos= query_get_value(SHOW SLAVE STATUS, Read_Master_Log_Pos, 1);
|
--replace_result $MASTER_MYPORT MASTER_MYPORT
|
||||||
let $exec_pos= query_get_value(SHOW SLAVE STATUS, Exec_Master_Log_Pos, 1);
|
--replace_column 1 # 7 # 8 # 9 # 23 # 33 #
|
||||||
if (`SELECT $read_pos <> $exec_pos`)
|
show slave status;
|
||||||
{
|
|
||||||
source include/show_rpl_debug_info.inc;
|
|
||||||
echo 'Read_Master_Log_Pos: $read_pos' <> 'Exec_Master_Log_Pos: $exec_pos';
|
|
||||||
die Failed because Read_Master_Log_Pos is not equal to Exec_Master_Log_Pos;
|
|
||||||
}
|
|
||||||
|
|
||||||
start slave;
|
start slave;
|
||||||
sync_with_master;
|
sync_with_master;
|
||||||
select * from t1;
|
select * from t1;
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
source include/master-slave.inc;
|
source include/master-slave.inc;
|
||||||
|
|
||||||
|
--replace_column 1 # 8 # 9 # 16 # 23 # 33 #
|
||||||
|
show slave status;
|
||||||
|
|
||||||
#
|
#
|
||||||
# Load table should not succeed on the master as this is not a slave
|
# Load table should not succeed on the master as this is not a slave
|
||||||
#
|
#
|
||||||
|
@ -41,7 +41,8 @@ sleep 5;
|
|||||||
#
|
#
|
||||||
# Show status of slave
|
# Show status of slave
|
||||||
#
|
#
|
||||||
--let status_items= Relay_Log_File
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
||||||
--source include/show_slave_status.inc
|
--replace_column 1 # 8 # 9 # 16 # 23 # 33 #
|
||||||
--source include/check_slave_is_running.inc
|
--vertical_results
|
||||||
|
SHOW SLAVE STATUS;
|
||||||
STOP SLAVE;
|
STOP SLAVE;
|
||||||
|
@ -20,7 +20,9 @@ save_master_pos;
|
|||||||
connection slave;
|
connection slave;
|
||||||
sync_with_master;
|
sync_with_master;
|
||||||
select count(*) from test.t1; # check that LOAD was replicated
|
select count(*) from test.t1; # check that LOAD was replicated
|
||||||
source include/show_binlog_events.inc;
|
--replace_column 2 # 5 #
|
||||||
|
--replace_regex /table_id: [0-9]+/table_id: #/
|
||||||
|
show binlog events from 106; # should be nothing
|
||||||
|
|
||||||
# Cleanup
|
# Cleanup
|
||||||
connection master;
|
connection master;
|
||||||
|
@ -11,41 +11,36 @@
|
|||||||
# Passes with rbr no problem, removed statement include [jbm]
|
# Passes with rbr no problem, removed statement include [jbm]
|
||||||
|
|
||||||
source include/master-slave.inc;
|
source include/master-slave.inc;
|
||||||
let $master_log_pos= query_get_value(SHOW MASTER STATUS, Position, 1);
|
--replace_column 3 <Binlog_Ignore_DB>
|
||||||
|
show master status;
|
||||||
sync_slave_with_master;
|
sync_slave_with_master;
|
||||||
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
||||||
|
--replace_column 1 # 8 # 9 # 23 # 33 #
|
||||||
|
show slave status;
|
||||||
stop slave;
|
stop slave;
|
||||||
|
change master to master_log_pos=106;
|
||||||
--replace_result $master_log_pos MASTER_LOG_POS
|
|
||||||
eval change master to master_log_pos=$master_log_pos;
|
|
||||||
start slave;
|
start slave;
|
||||||
sleep 5;
|
sleep 5;
|
||||||
stop slave;
|
stop slave;
|
||||||
|
change master to master_log_pos=106;
|
||||||
--replace_result $master_log_pos MASTER_LOG_POS
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
||||||
eval change master to master_log_pos=$master_log_pos;
|
--replace_column 1 # 8 # 9 # 23 # 33 #
|
||||||
--let $slave_param= Read_Master_Log_Pos
|
show slave status;
|
||||||
--let $slave_param_value= $master_log_pos
|
|
||||||
--source include/wait_for_slave_param.inc
|
|
||||||
|
|
||||||
start slave;
|
start slave;
|
||||||
sleep 5;
|
sleep 5;
|
||||||
--let $slave_param= Read_Master_Log_Pos
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
||||||
--let $slave_param_value= $master_log_pos
|
--replace_column 1 # 8 # 9 # 23 # 33 #
|
||||||
--source include/wait_for_slave_param.inc
|
show slave status;
|
||||||
--source include/check_slave_no_error.inc
|
|
||||||
|
|
||||||
stop slave;
|
stop slave;
|
||||||
--echo # impossible position leads to an error
|
|
||||||
--replace_result 177 MASTER_LOG_POS
|
|
||||||
change master to master_log_pos=177;
|
change master to master_log_pos=177;
|
||||||
start slave;
|
start slave;
|
||||||
sleep 2;
|
sleep 2;
|
||||||
let $slave_io_errno= 1236;
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
||||||
let $show_slave_io_error= 1;
|
--replace_column 1 # 8 # 9 # 23 # 33 #
|
||||||
source include/wait_for_slave_io_error.inc;
|
show slave status;
|
||||||
connection master;
|
connection master;
|
||||||
|
--replace_column 3 <Binlog_Ignore_DB>
|
||||||
let $master_log_pos= query_get_value(SHOW MASTER STATUS, Position, 1);
|
show master status;
|
||||||
create table if not exists t1 (n int);
|
create table if not exists t1 (n int);
|
||||||
drop table if exists t1;
|
drop table if exists t1;
|
||||||
create table t1 (n int);
|
create table t1 (n int);
|
||||||
@ -53,9 +48,7 @@ insert into t1 values (1),(2),(3);
|
|||||||
save_master_pos;
|
save_master_pos;
|
||||||
connection slave;
|
connection slave;
|
||||||
stop slave;
|
stop slave;
|
||||||
|
change master to master_log_pos=206;
|
||||||
--replace_result $master_log_pos MASTER_LOG_POS
|
|
||||||
eval change master to master_log_pos=$master_log_pos;
|
|
||||||
start slave;
|
start slave;
|
||||||
sync_with_master;
|
sync_with_master;
|
||||||
select * from t1 ORDER BY n;
|
select * from t1 ORDER BY n;
|
||||||
|
@ -15,17 +15,25 @@ SELECT @@GLOBAL.BINLOG_FORMAT, @@SESSION.BINLOG_FORMAT;
|
|||||||
CREATE TABLE t1 (a INT, b LONG);
|
CREATE TABLE t1 (a INT, b LONG);
|
||||||
INSERT INTO t1 VALUES (1,1), (2,2);
|
INSERT INTO t1 VALUES (1,1), (2,2);
|
||||||
INSERT INTO t1 VALUES (3,UUID()), (4,UUID());
|
INSERT INTO t1 VALUES (3,UUID()), (4,UUID());
|
||||||
|
let $VERSION=`select version()`;
|
||||||
|
--replace_result $VERSION VERSION
|
||||||
|
--replace_column 2 # 5 #
|
||||||
|
--replace_regex /table_id: [0-9]+/table_id: #/
|
||||||
# Different number of binlog events are generated by different engines
|
# Different number of binlog events are generated by different engines
|
||||||
--disable_result_log
|
--disable_result_log
|
||||||
source include/show_binlog_events.inc;
|
SHOW BINLOG EVENTS;
|
||||||
--enable_result_log
|
--enable_result_log
|
||||||
sync_slave_with_master;
|
sync_slave_with_master;
|
||||||
--echo **** On Slave ****
|
--echo **** On Slave ****
|
||||||
source include/show_binlog_events.inc;
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
||||||
|
--replace_column 1 # 7 # 8 # 9 # 22 # 23 # 33 #
|
||||||
|
--query_vertical SHOW SLAVE STATUS
|
||||||
|
--replace_result $VERSION VERSION
|
||||||
|
--replace_column 2 # 5 #
|
||||||
|
--replace_regex /table_id: [0-9]+/table_id: #/
|
||||||
# Different number of binlog events are generated by different engines
|
# Different number of binlog events are generated by different engines
|
||||||
--disable_result_log
|
--disable_result_log
|
||||||
source include/show_binlog_events.inc;
|
SHOW BINLOG EVENTS;
|
||||||
--enable_result_log
|
--enable_result_log
|
||||||
--exec $MYSQL_DUMP --compact --order-by-primary --skip-extended-insert --no-create-info test > $MYSQLTEST_VARDIR/tmp/rpl_rbr_to_sbr_master.sql
|
--exec $MYSQL_DUMP --compact --order-by-primary --skip-extended-insert --no-create-info test > $MYSQLTEST_VARDIR/tmp/rpl_rbr_to_sbr_master.sql
|
||||||
--exec $MYSQL_DUMP_SLAVE --compact --order-by-primary --skip-extended-insert --no-create-info test > $MYSQLTEST_VARDIR/tmp/rpl_rbr_to_sbr_slave.sql
|
--exec $MYSQL_DUMP_SLAVE --compact --order-by-primary --skip-extended-insert --no-create-info test > $MYSQLTEST_VARDIR/tmp/rpl_rbr_to_sbr_slave.sql
|
||||||
|
@ -30,7 +30,10 @@ connection master;
|
|||||||
--echo **** On Master ****
|
--echo **** On Master ****
|
||||||
# Should drop the non-temporary table t1 and the temporary table t2
|
# Should drop the non-temporary table t1 and the temporary table t2
|
||||||
DROP TABLE t1,t2;
|
DROP TABLE t1,t2;
|
||||||
source include/show_binlog_events.inc;
|
let $VERSION=`select version()`;
|
||||||
|
--replace_result $VERSION VERSION
|
||||||
|
--replace_regex /table_id: [0-9]+/table_id: #/
|
||||||
|
SHOW BINLOG EVENTS;
|
||||||
SHOW TABLES;
|
SHOW TABLES;
|
||||||
sync_slave_with_master;
|
sync_slave_with_master;
|
||||||
--echo **** On Slave ****
|
--echo **** On Slave ****
|
||||||
|
@ -22,11 +22,13 @@ connection master;
|
|||||||
insert into t1 values (1);
|
insert into t1 values (1);
|
||||||
|
|
||||||
connection slave;
|
connection slave;
|
||||||
# slave should have stopped because can't find table t1
|
# slave should have stopped because can't find table t1
|
||||||
|
wait_for_slave_to_stop;
|
||||||
# see if we have a good error message:
|
# see if we have a good error message:
|
||||||
--let $slave_sql_errno= 1146
|
--replace_result $MASTER_MYPORT MASTER_MYPORT
|
||||||
--let $show_slave_sql_error= 1
|
--replace_column 1 # 7 # 8 # 9 # 22 # 23 # 33 #
|
||||||
--source include/wait_for_slave_sql_error.inc
|
--vertical_results
|
||||||
|
show slave status;
|
||||||
|
|
||||||
# cleanup
|
# cleanup
|
||||||
connection master;
|
connection master;
|
||||||
|
@ -18,50 +18,44 @@ connection master;
|
|||||||
# create some events on master
|
# create some events on master
|
||||||
create table t1(n int not null auto_increment primary key);
|
create table t1(n int not null auto_increment primary key);
|
||||||
insert into t1 values (1),(2),(3),(4);
|
insert into t1 values (1),(2),(3),(4);
|
||||||
let $master_log_pos_1= query_get_value(SHOW MASTER STATUS, Position, 1);
|
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
|
||||||
create table t2(n int not null auto_increment primary key);
|
create table t2(n int not null auto_increment primary key);
|
||||||
insert into t2 values (1),(2);
|
insert into t2 values (1),(2);
|
||||||
let $master_log_pos_2= query_get_value(SHOW MASTER STATUS, Position, 1);
|
|
||||||
insert into t2 values (3),(4);
|
insert into t2 values (3),(4);
|
||||||
drop table t2;
|
drop table t2;
|
||||||
|
|
||||||
# try to replicate all queries until drop of t1
|
# try to replicate all queries until drop of t1
|
||||||
connection slave;
|
connection slave;
|
||||||
--replace_result $master_log_pos_1 MASTER_LOG_POS
|
start slave until master_log_file='master-bin.000001', master_log_pos=311;
|
||||||
eval start slave until master_log_file='master-bin.000001', master_log_pos=$master_log_pos_1;
|
|
||||||
sleep 2;
|
sleep 2;
|
||||||
wait_for_slave_to_stop;
|
wait_for_slave_to_stop;
|
||||||
# here table should be still not deleted
|
# here table should be still not deleted
|
||||||
select * from t1;
|
select * from t1;
|
||||||
--let $slave_param= Exec_Master_Log_Pos
|
--vertical_results
|
||||||
--let $slave_param_value= $master_log_pos_1
|
--replace_result $MASTER_MYPORT MASTER_MYPORT
|
||||||
--source include/check_slave_param.inc
|
--replace_column 1 # 7 # 9 # 11 # 22 # 23 # 33 #
|
||||||
|
show slave status;
|
||||||
|
|
||||||
# this should fail right after start
|
# this should fail right after start
|
||||||
--replace_result 291 MASTER_LOG_POS
|
|
||||||
start slave until master_log_file='master-no-such-bin.000001', master_log_pos=291;
|
start slave until master_log_file='master-no-such-bin.000001', master_log_pos=291;
|
||||||
# again this table should be still not deleted
|
# again this table should be still not deleted
|
||||||
select * from t1;
|
select * from t1;
|
||||||
sleep 2;
|
sleep 2;
|
||||||
wait_for_slave_to_stop;
|
wait_for_slave_to_stop;
|
||||||
--let $slave_param= Exec_Master_Log_Pos
|
--vertical_results
|
||||||
--let $slave_param_value= $master_log_pos_1
|
--replace_result $MASTER_MYPORT MASTER_MYPORT
|
||||||
--source include/check_slave_param.inc
|
--replace_column 1 # 7 # 9 # 11 # 22 # 23 # 33 #
|
||||||
|
show slave status;
|
||||||
|
|
||||||
# try replicate all up to and not including the second insert to t2;
|
# try replicate all up to and not including the second insert to t2;
|
||||||
let $master_log_pos= $master_log_pos_2;
|
start slave until relay_log_file='slave-relay-bin.000004', relay_log_pos=728;
|
||||||
let $relay_log_file= slave-relay-bin.000004;
|
|
||||||
--source include/get_relay_log_pos.inc
|
|
||||||
--replace_result $relay_log_pos RELAY_LOG_POS
|
|
||||||
eval start slave until relay_log_file='$relay_log_file', relay_log_pos=$relay_log_pos;
|
|
||||||
sleep 2;
|
sleep 2;
|
||||||
wait_for_slave_to_stop;
|
wait_for_slave_to_stop;
|
||||||
select * from t2;
|
select * from t2;
|
||||||
--let $slave_param= Exec_Master_Log_Pos
|
--vertical_results
|
||||||
--let $slave_param_value= $master_log_pos
|
--replace_result $MASTER_MYPORT MASTER_MYPORT
|
||||||
--source include/check_slave_param.inc
|
--replace_column 1 # 7 # 9 # 11 # 22 # 23 # 33 #
|
||||||
|
show slave status;
|
||||||
|
|
||||||
# clean up
|
# clean up
|
||||||
start slave;
|
start slave;
|
||||||
@ -71,32 +65,27 @@ connection slave;
|
|||||||
sync_with_master;
|
sync_with_master;
|
||||||
stop slave;
|
stop slave;
|
||||||
|
|
||||||
--let $exec_log_pos_1= query_get_value(SHOW SLAVE STATUS, Exec_Master_Log_Pos, 1)
|
|
||||||
# this should stop immediately as we are already there
|
# this should stop immediately as we are already there
|
||||||
--replace_result $master_log_pos_2 MASTER_LOG_POS
|
start slave until master_log_file='master-bin.000001', master_log_pos=740;
|
||||||
eval start slave until master_log_file='master-bin.000001', master_log_pos=$master_log_pos_2;
|
|
||||||
sleep 2;
|
sleep 2;
|
||||||
wait_for_slave_to_stop;
|
wait_for_slave_to_stop;
|
||||||
# here the sql slave thread should be stopped
|
# here the sql slave thread should be stopped
|
||||||
--let $slave_param= Exec_Master_Log_Pos
|
--vertical_results
|
||||||
--let $slave_param_value= $exec_log_pos_1
|
--replace_result $MASTER_MYPORT MASTER_MYPORT bin.000005 bin.000004 bin.000006 bin.000004 bin.000007 bin.000004
|
||||||
--source include/check_slave_param.inc
|
--replace_column 1 # 7 # 9 # 22 # 23 # 33 #
|
||||||
|
show slave status;
|
||||||
|
|
||||||
#testing various error conditions
|
#testing various error conditions
|
||||||
--replace_result 561 MASTER_LOG_POS
|
|
||||||
--error 1277
|
--error 1277
|
||||||
start slave until master_log_file='master-bin', master_log_pos=561;
|
start slave until master_log_file='master-bin', master_log_pos=561;
|
||||||
--replace_result 561 MASTER_LOG_POS 12 RELAY_LOG_POS
|
|
||||||
--error 1277
|
--error 1277
|
||||||
start slave until master_log_file='master-bin.000001', master_log_pos=561, relay_log_pos=12;
|
start slave until master_log_file='master-bin.000001', master_log_pos=561, relay_log_pos=12;
|
||||||
--error 1277
|
--error 1277
|
||||||
start slave until master_log_file='master-bin.000001';
|
start slave until master_log_file='master-bin.000001';
|
||||||
--error 1277
|
--error 1277
|
||||||
start slave until relay_log_file='slave-relay-bin.000002';
|
start slave until relay_log_file='slave-relay-bin.000002';
|
||||||
--replace_result 561 MASTER_LOG_POS
|
|
||||||
--error 1277
|
--error 1277
|
||||||
start slave until relay_log_file='slave-relay-bin.000002', master_log_pos=561;
|
start slave until relay_log_file='slave-relay-bin.000002', master_log_pos=561;
|
||||||
# Warning should be given for second command
|
# Warning should be given for second command
|
||||||
start slave sql_thread;
|
start slave sql_thread;
|
||||||
--replace_result 740 MASTER_LOG_POS
|
|
||||||
start slave until master_log_file='master-bin.000001', master_log_pos=740;
|
start slave until master_log_file='master-bin.000001', master_log_pos=740;
|
||||||
|
@ -12,13 +12,10 @@ reset master;
|
|||||||
stop slave;
|
stop slave;
|
||||||
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
||||||
eval change master to master_port=$SLAVE_MYPORT;
|
eval change master to master_port=$SLAVE_MYPORT;
|
||||||
source include/check_slave_no_error.inc;
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
||||||
|
--replace_column 16 # 18 #
|
||||||
|
show slave status;
|
||||||
start slave;
|
start slave;
|
||||||
let $slave_io_errno= 1593;
|
|
||||||
let $show_slave_io_error= 1;
|
|
||||||
source include/wait_for_slave_io_error.inc;
|
|
||||||
|
|
||||||
insert into t1 values (1);
|
insert into t1 values (1);
|
||||||
# can't MASTER_POS_WAIT(), it does not work in this weird setup
|
# can't MASTER_POS_WAIT(), it does not work in this weird setup
|
||||||
# (when slave is its own master without --replicate-same-server-id)
|
# (when slave is its own master without --replicate-same-server-id)
|
||||||
|
@ -9,6 +9,9 @@ reset master;
|
|||||||
stop slave;
|
stop slave;
|
||||||
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
||||||
eval change master to master_port=$SLAVE_MYPORT;
|
eval change master to master_port=$SLAVE_MYPORT;
|
||||||
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
||||||
|
--replace_column 18 #
|
||||||
|
show slave status;
|
||||||
start slave;
|
start slave;
|
||||||
insert into t1 values (1);
|
insert into t1 values (1);
|
||||||
save_master_pos;
|
save_master_pos;
|
||||||
|
@ -22,7 +22,9 @@ drop table if exists t1;
|
|||||||
--enable_warnings
|
--enable_warnings
|
||||||
create table t1 (n int);
|
create table t1 (n int);
|
||||||
insert into t1 values (1);
|
insert into t1 values (1);
|
||||||
sync_slave_with_master;
|
save_master_pos;
|
||||||
|
connection slave;
|
||||||
|
sync_with_master;
|
||||||
select * from t1;
|
select * from t1;
|
||||||
|
|
||||||
# 3. Delete new replication user
|
# 3. Delete new replication user
|
||||||
@ -38,8 +40,12 @@ stop slave;
|
|||||||
start slave;
|
start slave;
|
||||||
|
|
||||||
# 5. Make sure Slave_IO_Running = No
|
# 5. Make sure Slave_IO_Running = No
|
||||||
let $slave_io_errno= 1045;
|
--replace_result $MASTER_MYPORT MASTER_MYPORT
|
||||||
source include/wait_for_slave_io_error.inc;
|
# Column 1 is replaced, since the output can be either
|
||||||
|
# "Connecting to master" or "Waiting for master update"
|
||||||
|
--replace_column 1 # 7 # 8 # 9 # 22 # 23 # 35 # 36 #
|
||||||
|
--vertical_results
|
||||||
|
show slave status;
|
||||||
|
|
||||||
# Cleanup (Note that slave IO thread is not running)
|
# Cleanup (Note that slave IO thread is not running)
|
||||||
connection slave;
|
connection slave;
|
||||||
|
@ -501,7 +501,9 @@ INSERT INTO t12 VALUES(UUID());
|
|||||||
UNLOCK TABLES;
|
UNLOCK TABLES;
|
||||||
|
|
||||||
--disable_result_log
|
--disable_result_log
|
||||||
source include/show_binlog_events.inc;
|
--replace_column 2 # 5 #
|
||||||
|
--replace_regex /table_id: [0-9]+/table_id: #/
|
||||||
|
show binlog events;
|
||||||
--enable_result_log
|
--enable_result_log
|
||||||
sync_slave_with_master;
|
sync_slave_with_master;
|
||||||
|
|
||||||
@ -518,7 +520,9 @@ diff_files $MYSQLTEST_VARDIR/tmp/rpl_switch_stm_row_mixed_master.sql $MYSQLTEST_
|
|||||||
|
|
||||||
connection master;
|
connection master;
|
||||||
--disable_result_log
|
--disable_result_log
|
||||||
source include/show_binlog_events.inc;
|
--replace_column 2 # 5 #
|
||||||
|
--replace_regex /table_id: [0-9]+/table_id: #/
|
||||||
|
show binlog events;
|
||||||
--enable_result_log
|
--enable_result_log
|
||||||
|
|
||||||
# Now test that mysqlbinlog works fine on a binlog generated by the
|
# Now test that mysqlbinlog works fine on a binlog generated by the
|
||||||
|
@ -226,6 +226,7 @@ SELECT * FROM t2 WHERE c1 IS NOT NULL ORDER BY c1,c2 DESC LIMIT 2;
|
|||||||
## Full table scan ##
|
## Full table scan ##
|
||||||
--sorted_result
|
--sorted_result
|
||||||
SELECT * FROM t2;
|
SELECT * FROM t2;
|
||||||
|
|
||||||
--sorted_result
|
--sorted_result
|
||||||
SELECT count(*) as total_rows, min(c2) as min_value, max(c2) FROM t2;
|
SELECT count(*) as total_rows, min(c2) as min_value, max(c2) FROM t2;
|
||||||
--sorted_result
|
--sorted_result
|
||||||
@ -300,6 +301,7 @@ SELECT * FROM t2 WHERE c2 IS NOT NULL ORDER BY c1,c2 DESC LIMIT 2;
|
|||||||
## Full table scan ##
|
## Full table scan ##
|
||||||
--sorted_result
|
--sorted_result
|
||||||
SELECT * FROM t2;
|
SELECT * FROM t2;
|
||||||
|
|
||||||
--sorted_result
|
--sorted_result
|
||||||
SELECT count(*) as total_rows, min(c2) as min_value, max(c2) FROM t2;
|
SELECT count(*) as total_rows, min(c2) as min_value, max(c2) FROM t2;
|
||||||
--sorted_result
|
--sorted_result
|
||||||
|
@ -1,6 +1,9 @@
|
|||||||
#### suite/funcs_1/t/myisam_views.test
|
#### suite/funcs_1/t/myisam_views.test
|
||||||
|
|
||||||
--source include/no_valgrind_without_big.inc
|
--source include/no_valgrind_without_big.inc
|
||||||
|
# because of a pair of slow Solaris Sparc machines in pb2,
|
||||||
|
# this test is marked as big:
|
||||||
|
--source include/big_test.inc
|
||||||
|
|
||||||
# MyISAM tables should be used
|
# MyISAM tables should be used
|
||||||
#
|
#
|
@ -12,6 +12,7 @@ create table C(id int not null auto_increment primary key, f1 int not null, fore
|
|||||||
insert into A values(1), (2);
|
insert into A values(1), (2);
|
||||||
|
|
||||||
--disable_query_log
|
--disable_query_log
|
||||||
|
begin;
|
||||||
let $i=257;
|
let $i=257;
|
||||||
while ($i)
|
while ($i)
|
||||||
{
|
{
|
||||||
@ -24,6 +25,7 @@ while ($i)
|
|||||||
insert into C(f1) values(2);
|
insert into C(f1) values(2);
|
||||||
dec $i;
|
dec $i;
|
||||||
}
|
}
|
||||||
|
commit;
|
||||||
--enable_query_log
|
--enable_query_log
|
||||||
|
|
||||||
# Following Deletes should not report error
|
# Following Deletes should not report error
|
||||||
|
26
mysql-test/suite/innodb_plugin/r/innodb-autoinc-18274.result
Normal file
26
mysql-test/suite/innodb_plugin/r/innodb-autoinc-18274.result
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
drop table if exists t1;
|
||||||
|
SET @@SESSION.AUTO_INCREMENT_INCREMENT=1, @@SESSION.AUTO_INCREMENT_OFFSET=1;
|
||||||
|
CREATE TABLE t1 (c1 INT PRIMARY KEY AUTO_INCREMENT) ENGINE=InnoDB;
|
||||||
|
INSERT INTO t1 VALUES (null);
|
||||||
|
SHOW CREATE TABLE t1;
|
||||||
|
Table Create Table
|
||||||
|
t1 CREATE TABLE `t1` (
|
||||||
|
`c1` int(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
PRIMARY KEY (`c1`)
|
||||||
|
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=latin1
|
||||||
|
DELETE FROM t1;
|
||||||
|
OPTIMIZE TABLE t1;
|
||||||
|
Table Op Msg_type Msg_text
|
||||||
|
test.t1 optimize note Table does not support optimize, doing recreate + analyze instead
|
||||||
|
test.t1 optimize status OK
|
||||||
|
SHOW CREATE TABLE t1;
|
||||||
|
Table Create Table
|
||||||
|
t1 CREATE TABLE `t1` (
|
||||||
|
`c1` int(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
PRIMARY KEY (`c1`)
|
||||||
|
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=latin1
|
||||||
|
INSERT INTO t1 VALUES(null);
|
||||||
|
SELECT * FROM t1;
|
||||||
|
c1
|
||||||
|
2
|
||||||
|
DROP TABLE t1;
|
@ -1,5 +1,8 @@
|
|||||||
drop table if exists t1,t2,t3,t4;
|
drop table if exists t1,t2,t3,t4;
|
||||||
drop database if exists mysqltest;
|
drop database if exists mysqltest;
|
||||||
|
CREATE TABLE bug58912 (a BLOB, b TEXT, PRIMARY KEY(a(1))) ENGINE=InnoDB;
|
||||||
|
INSERT INTO bug58912 VALUES(REPEAT('a',8000),REPEAT('b',8000));
|
||||||
|
UPDATE bug58912 SET a=REPEAT('a',7999);
|
||||||
create table t1 (id int unsigned not null auto_increment, code tinyint unsigned not null, name char(20) not null, primary key (id), key (code), unique (name)) engine=innodb;
|
create table t1 (id int unsigned not null auto_increment, code tinyint unsigned not null, name char(20) not null, primary key (id), key (code), unique (name)) engine=innodb;
|
||||||
insert into t1 (code, name) values (1, 'Tim'), (1, 'Monty'), (2, 'David'), (2, 'Erik'), (3, 'Sasha'), (3, 'Jeremy'), (4, 'Matt');
|
insert into t1 (code, name) values (1, 'Tim'), (1, 'Monty'), (2, 'David'), (2, 'Erik'), (3, 'Sasha'), (3, 'Jeremy'), (4, 'Matt');
|
||||||
select id, code, name from t1 order by id;
|
select id, code, name from t1 order by id;
|
||||||
@ -1676,10 +1679,10 @@ variable_value - @innodb_rows_deleted_orig
|
|||||||
71
|
71
|
||||||
SELECT variable_value - @innodb_rows_inserted_orig FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_rows_inserted';
|
SELECT variable_value - @innodb_rows_inserted_orig FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_rows_inserted';
|
||||||
variable_value - @innodb_rows_inserted_orig
|
variable_value - @innodb_rows_inserted_orig
|
||||||
1066
|
1067
|
||||||
SELECT variable_value - @innodb_rows_updated_orig FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_rows_updated';
|
SELECT variable_value - @innodb_rows_updated_orig FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_rows_updated';
|
||||||
variable_value - @innodb_rows_updated_orig
|
variable_value - @innodb_rows_updated_orig
|
||||||
865
|
866
|
||||||
SELECT variable_value - @innodb_row_lock_waits_orig FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_row_lock_waits';
|
SELECT variable_value - @innodb_row_lock_waits_orig FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_row_lock_waits';
|
||||||
variable_value - @innodb_row_lock_waits_orig
|
variable_value - @innodb_row_lock_waits_orig
|
||||||
0
|
0
|
||||||
@ -3239,3 +3242,4 @@ Variable_name Value
|
|||||||
Handler_update 1
|
Handler_update 1
|
||||||
Variable_name Value
|
Variable_name Value
|
||||||
Handler_delete 1
|
Handler_delete 1
|
||||||
|
DROP TABLE bug58912;
|
||||||
|
29
mysql-test/suite/innodb_plugin/t/innodb-autoinc-18274.test
Normal file
29
mysql-test/suite/innodb_plugin/t/innodb-autoinc-18274.test
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
-- source include/have_innodb_plugin.inc
|
||||||
|
# embedded server ignores 'delayed', so skip this
|
||||||
|
-- source include/not_embedded.inc
|
||||||
|
|
||||||
|
let $innodb_file_format_check_orig=`select @@innodb_file_format_check`;
|
||||||
|
|
||||||
|
--disable_warnings
|
||||||
|
drop table if exists t1;
|
||||||
|
--enable_warnings
|
||||||
|
|
||||||
|
#
|
||||||
|
# Bug #18274 InnoDB auto_increment field reset on OPTIMIZE TABLE
|
||||||
|
SET @@SESSION.AUTO_INCREMENT_INCREMENT=1, @@SESSION.AUTO_INCREMENT_OFFSET=1;
|
||||||
|
CREATE TABLE t1 (c1 INT PRIMARY KEY AUTO_INCREMENT) ENGINE=InnoDB;
|
||||||
|
INSERT INTO t1 VALUES (null);
|
||||||
|
SHOW CREATE TABLE t1;
|
||||||
|
DELETE FROM t1;
|
||||||
|
OPTIMIZE TABLE t1;
|
||||||
|
SHOW CREATE TABLE t1;
|
||||||
|
INSERT INTO t1 VALUES(null);
|
||||||
|
SELECT * FROM t1;
|
||||||
|
DROP TABLE t1;
|
||||||
|
|
||||||
|
#
|
||||||
|
# restore environment to the state it was before this test execution
|
||||||
|
#
|
||||||
|
|
||||||
|
-- disable_query_log
|
||||||
|
eval set global innodb_file_format_check=$innodb_file_format_check_orig;
|
@ -43,6 +43,15 @@ drop table if exists t1,t2,t3,t4;
|
|||||||
drop database if exists mysqltest;
|
drop database if exists mysqltest;
|
||||||
--enable_warnings
|
--enable_warnings
|
||||||
|
|
||||||
|
# Bug#58912 InnoDB unnecessarily avoids update-in-place on column prefixes
|
||||||
|
CREATE TABLE bug58912 (a BLOB, b TEXT, PRIMARY KEY(a(1))) ENGINE=InnoDB;
|
||||||
|
INSERT INTO bug58912 VALUES(REPEAT('a',8000),REPEAT('b',8000));
|
||||||
|
UPDATE bug58912 SET a=REPEAT('a',7999);
|
||||||
|
# The above statements used to trigger a failure during purge when
|
||||||
|
# Bug#55284 was fixed while Bug#58912 was not. Defer the DROP TABLE,
|
||||||
|
# so that purge gets a chance to run (and a double free of the
|
||||||
|
# off-page column can be detected, if one is to occur.)
|
||||||
|
|
||||||
#
|
#
|
||||||
# Small basic test with ignore
|
# Small basic test with ignore
|
||||||
#
|
#
|
||||||
@ -2541,6 +2550,9 @@ SET GLOBAL innodb_thread_concurrency = @innodb_thread_concurrency_orig;
|
|||||||
|
|
||||||
-- enable_query_log
|
-- enable_query_log
|
||||||
|
|
||||||
|
# Clean up after the Bug#55284/Bug#58912 test case.
|
||||||
|
DROP TABLE bug58912;
|
||||||
|
|
||||||
#######################################################################
|
#######################################################################
|
||||||
# #
|
# #
|
||||||
# Please, DO NOT TOUCH this file as well as the innodb.result file. #
|
# Please, DO NOT TOUCH this file as well as the innodb.result file. #
|
||||||
|
@ -12,6 +12,7 @@ create table C(id int not null auto_increment primary key, f1 int not null, fore
|
|||||||
insert into A values(1), (2);
|
insert into A values(1), (2);
|
||||||
|
|
||||||
--disable_query_log
|
--disable_query_log
|
||||||
|
begin;
|
||||||
let $i=257;
|
let $i=257;
|
||||||
while ($i)
|
while ($i)
|
||||||
{
|
{
|
||||||
@ -24,6 +25,7 @@ while ($i)
|
|||||||
insert into C(f1) values(2);
|
insert into C(f1) values(2);
|
||||||
dec $i;
|
dec $i;
|
||||||
}
|
}
|
||||||
|
commit;
|
||||||
--enable_query_log
|
--enable_query_log
|
||||||
|
|
||||||
# Following Deletes should not report error
|
# Following Deletes should not report error
|
||||||
|
@ -12,3 +12,4 @@
|
|||||||
|
|
||||||
rpl_row_create_table : Bug#51574 Feb 27 2010 andrei failed different way than earlier with bug#45576
|
rpl_row_create_table : Bug#51574 Feb 27 2010 andrei failed different way than earlier with bug#45576
|
||||||
rpl_log_pos : BUG#55675 Sep 10 2010 27 2010 alfranio rpl.rpl_log_pos fails sporadically with error binlog truncated in the middle
|
rpl_log_pos : BUG#55675 Sep 10 2010 27 2010 alfranio rpl.rpl_log_pos fails sporadically with error binlog truncated in the middle
|
||||||
|
rpl_get_master_version_and_clock : Bug#59178 Jan 05 2011 joro Valgrind warnings rpl_get_master_version_and_clock
|
||||||
|
@ -363,3 +363,20 @@ SET @@SESSION.AUTO_INCREMENT_OFFSET=default;
|
|||||||
DROP TABLE t1;
|
DROP TABLE t1;
|
||||||
|
|
||||||
--echo End of 5.1 tests
|
--echo End of 5.1 tests
|
||||||
|
|
||||||
|
--echo #
|
||||||
|
--echo # Bug#50619 assert in handler::update_auto_increment
|
||||||
|
--echo #
|
||||||
|
|
||||||
|
CREATE TABLE t1 (pk INT AUTO_INCREMENT, PRIMARY KEY (pk));
|
||||||
|
# This triggered the assert
|
||||||
|
INSERT INTO t1 VALUES (NULL), (-1), (NULL);
|
||||||
|
SELECT * FROM t1;
|
||||||
|
DROP TABLE t1;
|
||||||
|
|
||||||
|
# Check that that true overflow still gives error
|
||||||
|
CREATE TABLE t1 (pk BIGINT UNSIGNED AUTO_INCREMENT, PRIMARY KEY (pk));
|
||||||
|
--error ER_AUTOINC_READ_FAILED
|
||||||
|
INSERT INTO t1 VALUES (NULL), (18446744073709551615-1), (NULL);
|
||||||
|
SELECT * FROM t1;
|
||||||
|
DROP TABLE t1;
|
||||||
|
135
mysys/my_fopen.c
135
mysys/my_fopen.c
@ -18,6 +18,10 @@
|
|||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include "mysys_err.h"
|
#include "mysys_err.h"
|
||||||
|
|
||||||
|
#if defined(__FreeBSD__)
|
||||||
|
extern int getosreldate(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
static void make_ftype(char * to,int flag);
|
static void make_ftype(char * to,int flag);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -97,8 +101,137 @@ FILE *my_fopen(const char *filename, int flags, myf MyFlags)
|
|||||||
} /* my_fopen */
|
} /* my_fopen */
|
||||||
|
|
||||||
|
|
||||||
/* Close a stream */
|
#if defined(_WIN32)
|
||||||
|
|
||||||
|
static FILE *my_win_freopen(const char *path, const char *mode, FILE *stream)
|
||||||
|
{
|
||||||
|
int handle_fd, fd= _fileno(stream);
|
||||||
|
HANDLE osfh;
|
||||||
|
|
||||||
|
DBUG_ASSERT(path && stream);
|
||||||
|
|
||||||
|
/* Services don't have stdout/stderr on Windows, so _fileno returns -1. */
|
||||||
|
if (fd < 0)
|
||||||
|
{
|
||||||
|
if (!freopen(path, mode, stream))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
fd= _fileno(stream);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((osfh= CreateFile(path, GENERIC_READ | GENERIC_WRITE,
|
||||||
|
FILE_SHARE_READ | FILE_SHARE_WRITE |
|
||||||
|
FILE_SHARE_DELETE, NULL,
|
||||||
|
OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL,
|
||||||
|
NULL)) == INVALID_HANDLE_VALUE)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
if ((handle_fd= _open_osfhandle((intptr_t)osfh,
|
||||||
|
_O_APPEND | _O_TEXT)) == -1)
|
||||||
|
{
|
||||||
|
CloseHandle(osfh);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_dup2(handle_fd, fd) < 0)
|
||||||
|
{
|
||||||
|
CloseHandle(osfh);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
_close(handle_fd);
|
||||||
|
|
||||||
|
return stream;
|
||||||
|
}
|
||||||
|
|
||||||
|
#elif defined(__FreeBSD__)
|
||||||
|
|
||||||
|
/* No close operation hook. */
|
||||||
|
|
||||||
|
static int no_close(void *cookie __attribute__((unused)))
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
A hack around a race condition in the implementation of freopen.
|
||||||
|
|
||||||
|
The race condition steams from the fact that the current fd of
|
||||||
|
the stream is closed before its number is used to duplicate the
|
||||||
|
new file descriptor. This defeats the desired atomicity of the
|
||||||
|
close and duplicate of dup2().
|
||||||
|
|
||||||
|
See PR number 79887 for reference:
|
||||||
|
http://www.freebsd.org/cgi/query-pr.cgi?pr=79887
|
||||||
|
*/
|
||||||
|
|
||||||
|
static FILE *my_freebsd_freopen(const char *path, const char *mode, FILE *stream)
|
||||||
|
{
|
||||||
|
int old_fd;
|
||||||
|
FILE *result;
|
||||||
|
|
||||||
|
flockfile(stream);
|
||||||
|
|
||||||
|
old_fd= fileno(stream);
|
||||||
|
|
||||||
|
/* Use a no operation close hook to avoid having the fd closed. */
|
||||||
|
stream->_close= no_close;
|
||||||
|
|
||||||
|
/* Relies on the implicit dup2 to close old_fd. */
|
||||||
|
result= freopen(path, mode, stream);
|
||||||
|
|
||||||
|
/* If successful, the _close hook was replaced. */
|
||||||
|
|
||||||
|
if (result == NULL)
|
||||||
|
close(old_fd);
|
||||||
|
else
|
||||||
|
funlockfile(result);
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Change the file associated with a file stream.
|
||||||
|
|
||||||
|
@param path Path to file.
|
||||||
|
@param mode Mode of the stream.
|
||||||
|
@param stream File stream.
|
||||||
|
|
||||||
|
@note
|
||||||
|
This function is used to redirect stdout and stderr to a file and
|
||||||
|
subsequently to close and reopen that file for log rotation.
|
||||||
|
|
||||||
|
@retval A FILE pointer on success. Otherwise, NULL.
|
||||||
|
*/
|
||||||
|
|
||||||
|
FILE *my_freopen(const char *path, const char *mode, FILE *stream)
|
||||||
|
{
|
||||||
|
FILE *result;
|
||||||
|
|
||||||
|
#if defined(_WIN32)
|
||||||
|
result= my_win_freopen(path, mode, stream);
|
||||||
|
#elif defined(__FreeBSD__)
|
||||||
|
/*
|
||||||
|
XXX: Once the fix is ported to the stable releases, this should
|
||||||
|
be dependent upon the specific FreeBSD versions. Check at:
|
||||||
|
http://www.freebsd.org/cgi/query-pr.cgi?pr=79887
|
||||||
|
*/
|
||||||
|
if (getosreldate() > 900027)
|
||||||
|
result= freopen(path, mode, stream);
|
||||||
|
else
|
||||||
|
result= my_freebsd_freopen(path, mode, stream);
|
||||||
|
#else
|
||||||
|
result= freopen(path, mode, stream);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Close a stream */
|
||||||
int my_fclose(FILE *fd, myf MyFlags)
|
int my_fclose(FILE *fd, myf MyFlags)
|
||||||
{
|
{
|
||||||
int err,file;
|
int err,file;
|
||||||
|
76
sql/log.cc
76
sql/log.cc
@ -5171,80 +5171,26 @@ void sql_perror(const char *message)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef __WIN__
|
/*
|
||||||
|
Change the file associated with two output streams. Used to
|
||||||
|
redirect stdout and stderr to a file. The streams are reopened
|
||||||
|
only for appending (writing at end of file).
|
||||||
|
*/
|
||||||
extern "C" my_bool reopen_fstreams(const char *filename,
|
extern "C" my_bool reopen_fstreams(const char *filename,
|
||||||
FILE *outstream, FILE *errstream)
|
FILE *outstream, FILE *errstream)
|
||||||
{
|
{
|
||||||
int handle_fd;
|
if (outstream && !my_freopen(filename, "a", outstream))
|
||||||
int err_fd, out_fd;
|
return TRUE;
|
||||||
HANDLE osfh;
|
|
||||||
|
|
||||||
DBUG_ASSERT(filename && errstream);
|
if (errstream && !my_freopen(filename, "a", errstream))
|
||||||
|
return TRUE;
|
||||||
// Services don't have stdout/stderr on Windows, so _fileno returns -1.
|
|
||||||
err_fd= _fileno(errstream);
|
|
||||||
if (err_fd < 0)
|
|
||||||
{
|
|
||||||
if (!freopen(filename, "a+", errstream))
|
|
||||||
return TRUE;
|
|
||||||
|
|
||||||
|
/* The error stream must be unbuffered. */
|
||||||
|
if (errstream)
|
||||||
setbuf(errstream, NULL);
|
setbuf(errstream, NULL);
|
||||||
err_fd= _fileno(errstream);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (outstream)
|
|
||||||
{
|
|
||||||
out_fd= _fileno(outstream);
|
|
||||||
if (out_fd < 0)
|
|
||||||
{
|
|
||||||
if (!freopen(filename, "a+", outstream))
|
|
||||||
return TRUE;
|
|
||||||
out_fd= _fileno(outstream);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((osfh= CreateFile(filename, GENERIC_READ | GENERIC_WRITE,
|
|
||||||
FILE_SHARE_READ | FILE_SHARE_WRITE |
|
|
||||||
FILE_SHARE_DELETE, NULL,
|
|
||||||
OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL,
|
|
||||||
NULL)) == INVALID_HANDLE_VALUE)
|
|
||||||
return TRUE;
|
|
||||||
|
|
||||||
if ((handle_fd= _open_osfhandle((intptr_t)osfh,
|
|
||||||
_O_APPEND | _O_TEXT)) == -1)
|
|
||||||
{
|
|
||||||
CloseHandle(osfh);
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (_dup2(handle_fd, err_fd) < 0)
|
|
||||||
{
|
|
||||||
CloseHandle(osfh);
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (outstream && _dup2(handle_fd, out_fd) < 0)
|
|
||||||
{
|
|
||||||
CloseHandle(osfh);
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
_close(handle_fd);
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
extern "C" my_bool reopen_fstreams(const char *filename,
|
|
||||||
FILE *outstream, FILE *errstream)
|
|
||||||
{
|
|
||||||
if (outstream && !freopen(filename, "a+", outstream))
|
|
||||||
return TRUE;
|
|
||||||
|
|
||||||
if (errstream && !freopen(filename, "a+", errstream))
|
|
||||||
return TRUE;
|
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -4647,9 +4647,10 @@ static int get_schema_constraints_record(THD *thd, TABLE_LIST *tables,
|
|||||||
TABLE *show_table= tables->table;
|
TABLE *show_table= tables->table;
|
||||||
KEY *key_info=show_table->key_info;
|
KEY *key_info=show_table->key_info;
|
||||||
uint primary_key= show_table->s->primary_key;
|
uint primary_key= show_table->s->primary_key;
|
||||||
show_table->file->info(HA_STATUS_VARIABLE |
|
|
||||||
HA_STATUS_NO_LOCK |
|
// This is not needed since no statistics are displayed.
|
||||||
HA_STATUS_TIME);
|
// show_table->file->info(HA_STATUS_VARIABLE | HA_STATUS_NO_LOCK | HA_STATUS_TIME);
|
||||||
|
|
||||||
for (uint i=0 ; i < show_table->s->keys ; i++, key_info++)
|
for (uint i=0 ; i < show_table->s->keys ; i++, key_info++)
|
||||||
{
|
{
|
||||||
if (i != primary_key && !(key_info->flags & HA_NOSAME))
|
if (i != primary_key && !(key_info->flags & HA_NOSAME))
|
||||||
@ -4831,9 +4832,10 @@ static int get_schema_key_column_usage_record(THD *thd,
|
|||||||
TABLE *show_table= tables->table;
|
TABLE *show_table= tables->table;
|
||||||
KEY *key_info=show_table->key_info;
|
KEY *key_info=show_table->key_info;
|
||||||
uint primary_key= show_table->s->primary_key;
|
uint primary_key= show_table->s->primary_key;
|
||||||
show_table->file->info(HA_STATUS_VARIABLE |
|
|
||||||
HA_STATUS_NO_LOCK |
|
// This is not needed since no statistics are displayed.
|
||||||
HA_STATUS_TIME);
|
// show_table->file->info(HA_STATUS_VARIABLE | HA_STATUS_NO_LOCK | HA_STATUS_TIME);
|
||||||
|
|
||||||
for (uint i=0 ; i < show_table->s->keys ; i++, key_info++)
|
for (uint i=0 ; i < show_table->s->keys ; i++, key_info++)
|
||||||
{
|
{
|
||||||
if (i != primary_key && !(key_info->flags & HA_NOSAME))
|
if (i != primary_key && !(key_info->flags & HA_NOSAME))
|
||||||
@ -5562,9 +5564,9 @@ get_referential_constraints_record(THD *thd, TABLE_LIST *tables,
|
|||||||
{
|
{
|
||||||
List<FOREIGN_KEY_INFO> f_key_list;
|
List<FOREIGN_KEY_INFO> f_key_list;
|
||||||
TABLE *show_table= tables->table;
|
TABLE *show_table= tables->table;
|
||||||
show_table->file->info(HA_STATUS_VARIABLE |
|
|
||||||
HA_STATUS_NO_LOCK |
|
// This is not needed since no statistics are displayed.
|
||||||
HA_STATUS_TIME);
|
// show_table->file->info(HA_STATUS_VARIABLE | HA_STATUS_NO_LOCK | HA_STATUS_TIME);
|
||||||
|
|
||||||
show_table->file->get_foreign_key_list(thd, &f_key_list);
|
show_table->file->get_foreign_key_list(thd, &f_key_list);
|
||||||
FOREIGN_KEY_INFO *f_key_info;
|
FOREIGN_KEY_INFO *f_key_info;
|
||||||
|
@ -610,7 +610,7 @@ btr_page_get_father_for_rec(
|
|||||||
"InnoDB: corruption. If the crash happens at "
|
"InnoDB: corruption. If the crash happens at "
|
||||||
"the database startup, see\n"
|
"the database startup, see\n"
|
||||||
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
|
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
|
||||||
"forcing-recovery.html about\n"
|
"forcing-innodb-recovery.html about\n"
|
||||||
"InnoDB: forcing recovery. "
|
"InnoDB: forcing recovery. "
|
||||||
"Then dump + drop + reimport.\n", stderr);
|
"Then dump + drop + reimport.\n", stderr);
|
||||||
}
|
}
|
||||||
|
@ -334,7 +334,7 @@ buf_page_is_corrupted(
|
|||||||
"InnoDB: tablespace but not the InnoDB "
|
"InnoDB: tablespace but not the InnoDB "
|
||||||
"log files. See\n"
|
"log files. See\n"
|
||||||
"InnoDB: http://dev.mysql.com/doc/refman/"
|
"InnoDB: http://dev.mysql.com/doc/refman/"
|
||||||
"5.1/en/forcing-recovery.html\n"
|
"5.1/en/forcing-innodb-recovery.html\n"
|
||||||
"InnoDB: for more information.\n",
|
"InnoDB: for more information.\n",
|
||||||
(ulong) mach_read_from_4(read_buf
|
(ulong) mach_read_from_4(read_buf
|
||||||
+ FIL_PAGE_OFFSET),
|
+ FIL_PAGE_OFFSET),
|
||||||
@ -2067,7 +2067,7 @@ buf_page_io_complete(
|
|||||||
" table for corruption.\n"
|
" table for corruption.\n"
|
||||||
"InnoDB: See also"
|
"InnoDB: See also"
|
||||||
" http://dev.mysql.com/doc/refman/5.1/en/"
|
" http://dev.mysql.com/doc/refman/5.1/en/"
|
||||||
"forcing-recovery.html\n"
|
"forcing-innodb-recovery.html\n"
|
||||||
"InnoDB: about forcing recovery.\n", stderr);
|
"InnoDB: about forcing recovery.\n", stderr);
|
||||||
|
|
||||||
if (srv_force_recovery < SRV_FORCE_IGNORE_CORRUPT) {
|
if (srv_force_recovery < SRV_FORCE_IGNORE_CORRUPT) {
|
||||||
|
@ -2217,7 +2217,7 @@ dict_scan_to(
|
|||||||
quote = '\0';
|
quote = '\0';
|
||||||
} else if (quote) {
|
} else if (quote) {
|
||||||
/* Within quotes: do nothing. */
|
/* Within quotes: do nothing. */
|
||||||
} else if (*ptr == '`' || *ptr == '"') {
|
} else if (*ptr == '`' || *ptr == '"' || *ptr == '\'') {
|
||||||
/* Starting quote: remember the quote character. */
|
/* Starting quote: remember the quote character. */
|
||||||
quote = *ptr;
|
quote = *ptr;
|
||||||
} else {
|
} else {
|
||||||
|
@ -87,6 +87,8 @@ dict_mem_table_create(
|
|||||||
|
|
||||||
table->big_rows = 0;
|
table->big_rows = 0;
|
||||||
|
|
||||||
|
table->fk_max_recusive_level = 0;
|
||||||
|
|
||||||
mutex_create(&table->autoinc_mutex, SYNC_DICT_AUTOINC_MUTEX);
|
mutex_create(&table->autoinc_mutex, SYNC_DICT_AUTOINC_MUTEX);
|
||||||
|
|
||||||
table->autoinc = 0;
|
table->autoinc = 0;
|
||||||
|
@ -3046,7 +3046,7 @@ fseg_free_page_low(
|
|||||||
crash:
|
crash:
|
||||||
fputs("InnoDB: Please refer to\n"
|
fputs("InnoDB: Please refer to\n"
|
||||||
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
|
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
|
||||||
"forcing-recovery.html\n"
|
"forcing-innodb-recovery.html\n"
|
||||||
"InnoDB: about forcing recovery.\n", stderr);
|
"InnoDB: about forcing recovery.\n", stderr);
|
||||||
ut_error;
|
ut_error;
|
||||||
}
|
}
|
||||||
|
@ -218,7 +218,7 @@ buf_block_align(
|
|||||||
"InnoDB: corruption. If this happens in an"
|
"InnoDB: corruption. If this happens in an"
|
||||||
" InnoDB database recovery, see\n"
|
" InnoDB database recovery, see\n"
|
||||||
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
|
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
|
||||||
"forcing-recovery.html\n"
|
"forcing-innodb-recovery.html\n"
|
||||||
"InnoDB: how to force recovery.\n",
|
"InnoDB: how to force recovery.\n",
|
||||||
ptr, frame_zero,
|
ptr, frame_zero,
|
||||||
buf_pool->high_end);
|
buf_pool->high_end);
|
||||||
@ -257,7 +257,7 @@ buf_frame_align(
|
|||||||
"InnoDB: corruption. If this happens in an"
|
"InnoDB: corruption. If this happens in an"
|
||||||
" InnoDB database recovery, see\n"
|
" InnoDB database recovery, see\n"
|
||||||
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
|
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
|
||||||
"forcing-recovery.html\n"
|
"forcing-innodb-recovery.html\n"
|
||||||
"InnoDB: how to force recovery.\n",
|
"InnoDB: how to force recovery.\n",
|
||||||
ptr, buf_pool->frame_zero,
|
ptr, buf_pool->frame_zero,
|
||||||
buf_pool->high_end);
|
buf_pool->high_end);
|
||||||
|
@ -1826,7 +1826,7 @@ recv_report_corrupt_log(
|
|||||||
"InnoDB: on your InnoDB tables to check that they are ok!\n"
|
"InnoDB: on your InnoDB tables to check that they are ok!\n"
|
||||||
"InnoDB: If mysqld crashes after this recovery, look at\n"
|
"InnoDB: If mysqld crashes after this recovery, look at\n"
|
||||||
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
|
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
|
||||||
"forcing-recovery.html\n"
|
"forcing-innodb-recovery.html\n"
|
||||||
"InnoDB: about forcing recovery.\n", stderr);
|
"InnoDB: about forcing recovery.\n", stderr);
|
||||||
|
|
||||||
fflush(stderr);
|
fflush(stderr);
|
||||||
|
@ -552,7 +552,7 @@ handle_new_error:
|
|||||||
" after the startup or when\n"
|
" after the startup or when\n"
|
||||||
"InnoDB: you dump the tables, look at\n"
|
"InnoDB: you dump the tables, look at\n"
|
||||||
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
|
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
|
||||||
"forcing-recovery.html"
|
"forcing-innodb-recovery.html"
|
||||||
" for help.\n", stderr);
|
" for help.\n", stderr);
|
||||||
|
|
||||||
} else if (err == DB_FOREIGN_EXCEED_MAX_CASCADE) {
|
} else if (err == DB_FOREIGN_EXCEED_MAX_CASCADE) {
|
||||||
|
@ -58,7 +58,7 @@ ut_dbg_assertion_failed(
|
|||||||
"InnoDB: immediately after the mysqld startup, there may be\n"
|
"InnoDB: immediately after the mysqld startup, there may be\n"
|
||||||
"InnoDB: corruption in the InnoDB tablespace. Please refer to\n"
|
"InnoDB: corruption in the InnoDB tablespace. Please refer to\n"
|
||||||
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
|
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
|
||||||
"forcing-recovery.html\n"
|
"forcing-innodb-recovery.html\n"
|
||||||
"InnoDB: about forcing recovery.\n", stderr);
|
"InnoDB: about forcing recovery.\n", stderr);
|
||||||
#if defined(UNIV_SYNC_DEBUG) || !defined(UT_DBG_USE_ABORT)
|
#if defined(UNIV_SYNC_DEBUG) || !defined(UT_DBG_USE_ABORT)
|
||||||
ut_dbg_stop_threads = TRUE;
|
ut_dbg_stop_threads = TRUE;
|
||||||
|
@ -1,4 +1,34 @@
|
|||||||
|
2011-01-06 The InnoDB Team
|
||||||
|
* handler/i_s.cc, include/trx0i_s.h, trx/trx0i_s.c:
|
||||||
|
Fix Bug#55397 cannot select from innodb_trx when trx_query contains
|
||||||
|
blobs that aren't strings
|
||||||
|
|
||||||
|
2011-01-04 The InnoDB Team
|
||||||
|
* dict/dict0dict.c:
|
||||||
|
Fix Bug#59197 double quote in field comment prevents foreign
|
||||||
|
key constraint creation
|
||||||
|
|
||||||
|
2010-12-21 The InnoDB Team
|
||||||
|
* include/btr0cur.h, include/row0upd.h, btr/btr0cur.c,
|
||||||
|
row/row0umod.c, row/row0upd.c:
|
||||||
|
Fix Bug#55284 Double free of off-page columns due to lock wait
|
||||||
|
while updating PRIMARY KEY
|
||||||
|
|
||||||
|
2010-12-21 The InnoDB Team
|
||||||
|
|
||||||
|
* include/data0data.h, include/data0data.ic, include/row0upd.h,
|
||||||
|
btr/btr0cur.c, row/row0purge.c, row/row0umod.c, row/row0upd.c,
|
||||||
|
innodb.result, innodb.test:
|
||||||
|
Fix Bug#58912 InnoDB unnecessarily avoids update-in-place
|
||||||
|
on column prefix indexes
|
||||||
|
|
||||||
|
2010-12-09 The InnoDB Team
|
||||||
|
|
||||||
|
* buf/buf0lru.c:
|
||||||
|
Fix Bug#57600 output of I/O sum[%lu] can go negative
|
||||||
|
|
||||||
2010-11-11 The InnoDB Team
|
2010-11-11 The InnoDB Team
|
||||||
|
|
||||||
* thr/thr0loc.c, trx/trx0i_s.c:
|
* thr/thr0loc.c, trx/trx0i_s.c:
|
||||||
Fix Bug#57802 Empty ASSERTION parameter passed to the HASH_SEARCH macro
|
Fix Bug#57802 Empty ASSERTION parameter passed to the HASH_SEARCH macro
|
||||||
|
|
||||||
|
@ -663,7 +663,7 @@ btr_page_get_father_node_ptr_func(
|
|||||||
" to fix the\n"
|
" to fix the\n"
|
||||||
"InnoDB: corruption. If the crash happens at "
|
"InnoDB: corruption. If the crash happens at "
|
||||||
"the database startup, see\n"
|
"the database startup, see\n"
|
||||||
"InnoDB: " REFMAN "forcing-recovery.html about\n"
|
"InnoDB: " REFMAN "forcing-innodb-recovery.html about\n"
|
||||||
"InnoDB: forcing recovery. "
|
"InnoDB: forcing recovery. "
|
||||||
"Then dump + drop + reimport.\n", stderr);
|
"Then dump + drop + reimport.\n", stderr);
|
||||||
|
|
||||||
|
@ -1756,7 +1756,8 @@ btr_cur_update_in_place(
|
|||||||
NOT call it if index is secondary */
|
NOT call it if index is secondary */
|
||||||
|
|
||||||
if (!dict_index_is_clust(index)
|
if (!dict_index_is_clust(index)
|
||||||
|| row_upd_changes_ord_field_binary(NULL, index, update)) {
|
|| row_upd_changes_ord_field_binary(NULL, NULL,
|
||||||
|
index, update)) {
|
||||||
|
|
||||||
/* Remove possible hash index pointer to this record */
|
/* Remove possible hash index pointer to this record */
|
||||||
btr_search_update_hash_on_delete(cursor);
|
btr_search_update_hash_on_delete(cursor);
|
||||||
@ -2508,27 +2509,24 @@ ulint
|
|||||||
btr_cur_del_mark_set_clust_rec(
|
btr_cur_del_mark_set_clust_rec(
|
||||||
/*===========================*/
|
/*===========================*/
|
||||||
ulint flags, /*!< in: undo logging and locking flags */
|
ulint flags, /*!< in: undo logging and locking flags */
|
||||||
btr_cur_t* cursor, /*!< in: cursor */
|
buf_block_t* block, /*!< in/out: buffer block of the record */
|
||||||
|
rec_t* rec, /*!< in/out: record */
|
||||||
|
dict_index_t* index, /*!< in: clustered index of the record */
|
||||||
|
const ulint* offsets,/*!< in: rec_get_offsets(rec) */
|
||||||
ibool val, /*!< in: value to set */
|
ibool val, /*!< in: value to set */
|
||||||
que_thr_t* thr, /*!< in: query thread */
|
que_thr_t* thr, /*!< in: query thread */
|
||||||
mtr_t* mtr) /*!< in: mtr */
|
mtr_t* mtr) /*!< in: mtr */
|
||||||
{
|
{
|
||||||
dict_index_t* index;
|
|
||||||
buf_block_t* block;
|
|
||||||
roll_ptr_t roll_ptr;
|
roll_ptr_t roll_ptr;
|
||||||
ulint err;
|
ulint err;
|
||||||
rec_t* rec;
|
|
||||||
page_zip_des_t* page_zip;
|
page_zip_des_t* page_zip;
|
||||||
trx_t* trx;
|
trx_t* trx;
|
||||||
mem_heap_t* heap = NULL;
|
|
||||||
ulint offsets_[REC_OFFS_NORMAL_SIZE];
|
|
||||||
ulint* offsets = offsets_;
|
|
||||||
rec_offs_init(offsets_);
|
|
||||||
|
|
||||||
rec = btr_cur_get_rec(cursor);
|
ut_ad(dict_index_is_clust(index));
|
||||||
index = cursor->index;
|
ut_ad(rec_offs_validate(rec, index, offsets));
|
||||||
ut_ad(!!page_rec_is_comp(rec) == dict_table_is_comp(index->table));
|
ut_ad(!!page_rec_is_comp(rec) == dict_table_is_comp(index->table));
|
||||||
offsets = rec_get_offsets(rec, index, offsets, ULINT_UNDEFINED, &heap);
|
ut_ad(buf_block_get_frame(block) == page_align(rec));
|
||||||
|
ut_ad(page_is_leaf(page_align(rec)));
|
||||||
|
|
||||||
#ifdef UNIV_DEBUG
|
#ifdef UNIV_DEBUG
|
||||||
if (btr_cur_print_record_ops && thr) {
|
if (btr_cur_print_record_ops && thr) {
|
||||||
@ -2540,13 +2538,12 @@ btr_cur_del_mark_set_clust_rec(
|
|||||||
ut_ad(dict_index_is_clust(index));
|
ut_ad(dict_index_is_clust(index));
|
||||||
ut_ad(!rec_get_deleted_flag(rec, rec_offs_comp(offsets)));
|
ut_ad(!rec_get_deleted_flag(rec, rec_offs_comp(offsets)));
|
||||||
|
|
||||||
err = lock_clust_rec_modify_check_and_lock(flags,
|
err = lock_clust_rec_modify_check_and_lock(flags, block,
|
||||||
btr_cur_get_block(cursor),
|
|
||||||
rec, index, offsets, thr);
|
rec, index, offsets, thr);
|
||||||
|
|
||||||
if (err != DB_SUCCESS) {
|
if (err != DB_SUCCESS) {
|
||||||
|
|
||||||
goto func_exit;
|
return(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
err = trx_undo_report_row_operation(flags, TRX_UNDO_MODIFY_OP, thr,
|
err = trx_undo_report_row_operation(flags, TRX_UNDO_MODIFY_OP, thr,
|
||||||
@ -2554,11 +2551,9 @@ btr_cur_del_mark_set_clust_rec(
|
|||||||
&roll_ptr);
|
&roll_ptr);
|
||||||
if (err != DB_SUCCESS) {
|
if (err != DB_SUCCESS) {
|
||||||
|
|
||||||
goto func_exit;
|
return(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
block = btr_cur_get_block(cursor);
|
|
||||||
|
|
||||||
if (block->is_hashed) {
|
if (block->is_hashed) {
|
||||||
rw_lock_x_lock(&btr_search_latch);
|
rw_lock_x_lock(&btr_search_latch);
|
||||||
}
|
}
|
||||||
@ -2581,10 +2576,6 @@ btr_cur_del_mark_set_clust_rec(
|
|||||||
btr_cur_del_mark_set_clust_rec_log(flags, rec, index, val, trx,
|
btr_cur_del_mark_set_clust_rec_log(flags, rec, index, val, trx,
|
||||||
roll_ptr, mtr);
|
roll_ptr, mtr);
|
||||||
|
|
||||||
func_exit:
|
|
||||||
if (UNIV_LIKELY_NULL(heap)) {
|
|
||||||
mem_heap_free(heap);
|
|
||||||
}
|
|
||||||
return(err);
|
return(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3476,108 +3467,36 @@ btr_cur_set_ownership_of_extern_field(
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************//**
|
/*******************************************************************//**
|
||||||
Marks not updated extern fields as not-owned by this record. The ownership
|
Marks non-updated off-page fields as disowned by this record. The ownership
|
||||||
is transferred to the updated record which is inserted elsewhere in the
|
must be transferred to the updated record which is inserted elsewhere in the
|
||||||
index tree. In purge only the owner of externally stored field is allowed
|
index tree. In purge only the owner of externally stored field is allowed
|
||||||
to free the field.
|
to free the field. */
|
||||||
@return TRUE if BLOB ownership was transferred */
|
|
||||||
UNIV_INTERN
|
UNIV_INTERN
|
||||||
ibool
|
void
|
||||||
btr_cur_mark_extern_inherited_fields(
|
btr_cur_disown_inherited_fields(
|
||||||
/*=================================*/
|
/*============================*/
|
||||||
page_zip_des_t* page_zip,/*!< in/out: compressed page whose uncompressed
|
page_zip_des_t* page_zip,/*!< in/out: compressed page whose uncompressed
|
||||||
part will be updated, or NULL */
|
part will be updated, or NULL */
|
||||||
rec_t* rec, /*!< in/out: record in a clustered index */
|
rec_t* rec, /*!< in/out: record in a clustered index */
|
||||||
dict_index_t* index, /*!< in: index of the page */
|
dict_index_t* index, /*!< in: index of the page */
|
||||||
const ulint* offsets,/*!< in: array returned by rec_get_offsets() */
|
const ulint* offsets,/*!< in: array returned by rec_get_offsets() */
|
||||||
const upd_t* update, /*!< in: update vector */
|
const upd_t* update, /*!< in: update vector */
|
||||||
mtr_t* mtr) /*!< in: mtr, or NULL if not logged */
|
mtr_t* mtr) /*!< in/out: mini-transaction */
|
||||||
{
|
{
|
||||||
ulint n;
|
|
||||||
ulint j;
|
|
||||||
ulint i;
|
ulint i;
|
||||||
ibool change_ownership = FALSE;
|
|
||||||
|
|
||||||
ut_ad(rec_offs_validate(rec, NULL, offsets));
|
ut_ad(rec_offs_validate(rec, index, offsets));
|
||||||
ut_ad(!rec_offs_comp(offsets) || !rec_get_node_ptr_flag(rec));
|
ut_ad(!rec_offs_comp(offsets) || !rec_get_node_ptr_flag(rec));
|
||||||
|
ut_ad(rec_offs_any_extern(offsets));
|
||||||
|
ut_ad(mtr);
|
||||||
|
|
||||||
if (!rec_offs_any_extern(offsets)) {
|
for (i = 0; i < rec_offs_n_fields(offsets); i++) {
|
||||||
|
if (rec_offs_nth_extern(offsets, i)
|
||||||
return(FALSE);
|
&& !upd_get_field_by_field_no(update, i)) {
|
||||||
}
|
|
||||||
|
|
||||||
n = rec_offs_n_fields(offsets);
|
|
||||||
|
|
||||||
for (i = 0; i < n; i++) {
|
|
||||||
if (rec_offs_nth_extern(offsets, i)) {
|
|
||||||
|
|
||||||
/* Check it is not in updated fields */
|
|
||||||
|
|
||||||
if (update) {
|
|
||||||
for (j = 0; j < upd_get_n_fields(update);
|
|
||||||
j++) {
|
|
||||||
if (upd_get_nth_field(update, j)
|
|
||||||
->field_no == i) {
|
|
||||||
|
|
||||||
goto updated;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
btr_cur_set_ownership_of_extern_field(
|
btr_cur_set_ownership_of_extern_field(
|
||||||
page_zip, rec, index, offsets, i, FALSE, mtr);
|
page_zip, rec, index, offsets, i, FALSE, mtr);
|
||||||
|
|
||||||
change_ownership = TRUE;
|
|
||||||
updated:
|
|
||||||
;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return(change_ownership);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*******************************************************************//**
|
|
||||||
The complement of the previous function: in an update entry may inherit
|
|
||||||
some externally stored fields from a record. We must mark them as inherited
|
|
||||||
in entry, so that they are not freed in a rollback. */
|
|
||||||
UNIV_INTERN
|
|
||||||
void
|
|
||||||
btr_cur_mark_dtuple_inherited_extern(
|
|
||||||
/*=================================*/
|
|
||||||
dtuple_t* entry, /*!< in/out: updated entry to be
|
|
||||||
inserted to clustered index */
|
|
||||||
const upd_t* update) /*!< in: update vector */
|
|
||||||
{
|
|
||||||
ulint i;
|
|
||||||
|
|
||||||
for (i = 0; i < dtuple_get_n_fields(entry); i++) {
|
|
||||||
|
|
||||||
dfield_t* dfield = dtuple_get_nth_field(entry, i);
|
|
||||||
byte* data;
|
|
||||||
ulint len;
|
|
||||||
ulint j;
|
|
||||||
|
|
||||||
if (!dfield_is_ext(dfield)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Check if it is in updated fields */
|
|
||||||
|
|
||||||
for (j = 0; j < upd_get_n_fields(update); j++) {
|
|
||||||
if (upd_get_nth_field(update, j)->field_no == i) {
|
|
||||||
|
|
||||||
goto is_updated;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
data = dfield_get_data(dfield);
|
|
||||||
len = dfield_get_len(dfield);
|
|
||||||
data[len - BTR_EXTERN_FIELD_REF_SIZE + BTR_EXTERN_LEN]
|
|
||||||
|= BTR_EXTERN_INHERITED_FLAG;
|
|
||||||
|
|
||||||
is_updated:
|
|
||||||
;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************//**
|
/*******************************************************************//**
|
||||||
@ -3615,29 +3534,6 @@ btr_cur_unmark_extern_fields(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************//**
|
|
||||||
Marks all extern fields in a dtuple as owned by the record. */
|
|
||||||
UNIV_INTERN
|
|
||||||
void
|
|
||||||
btr_cur_unmark_dtuple_extern_fields(
|
|
||||||
/*================================*/
|
|
||||||
dtuple_t* entry) /*!< in/out: clustered index entry */
|
|
||||||
{
|
|
||||||
ulint i;
|
|
||||||
|
|
||||||
for (i = 0; i < dtuple_get_n_fields(entry); i++) {
|
|
||||||
dfield_t* dfield = dtuple_get_nth_field(entry, i);
|
|
||||||
|
|
||||||
if (dfield_is_ext(dfield)) {
|
|
||||||
byte* data = dfield_get_data(dfield);
|
|
||||||
ulint len = dfield_get_len(dfield);
|
|
||||||
|
|
||||||
data[len - BTR_EXTERN_FIELD_REF_SIZE + BTR_EXTERN_LEN]
|
|
||||||
&= ~BTR_EXTERN_OWNER_FLAG;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*******************************************************************//**
|
/*******************************************************************//**
|
||||||
Flags the data tuple fields that are marked as extern storage in the
|
Flags the data tuple fields that are marked as extern storage in the
|
||||||
update vector. We use this function to remember which fields we must
|
update vector. We use this function to remember which fields we must
|
||||||
|
@ -375,7 +375,7 @@ buf_page_is_corrupted(
|
|||||||
"you may have copied the InnoDB\n"
|
"you may have copied the InnoDB\n"
|
||||||
"InnoDB: tablespace but not the InnoDB "
|
"InnoDB: tablespace but not the InnoDB "
|
||||||
"log files. See\n"
|
"log files. See\n"
|
||||||
"InnoDB: " REFMAN "forcing-recovery.html\n"
|
"InnoDB: " REFMAN "forcing-innodb-recovery.html\n"
|
||||||
"InnoDB: for more information.\n",
|
"InnoDB: for more information.\n",
|
||||||
(ulong) mach_read_from_4(read_buf
|
(ulong) mach_read_from_4(read_buf
|
||||||
+ FIL_PAGE_OFFSET),
|
+ FIL_PAGE_OFFSET),
|
||||||
@ -3240,7 +3240,7 @@ corrupt:
|
|||||||
"InnoDB: TABLE to scan your"
|
"InnoDB: TABLE to scan your"
|
||||||
" table for corruption.\n"
|
" table for corruption.\n"
|
||||||
"InnoDB: See also "
|
"InnoDB: See also "
|
||||||
REFMAN "forcing-recovery.html\n"
|
REFMAN "forcing-innodb-recovery.html\n"
|
||||||
"InnoDB: about forcing recovery.\n", stderr);
|
"InnoDB: about forcing recovery.\n", stderr);
|
||||||
|
|
||||||
if (srv_force_recovery < SRV_FORCE_IGNORE_CORRUPT) {
|
if (srv_force_recovery < SRV_FORCE_IGNORE_CORRUPT) {
|
||||||
|
@ -1942,6 +1942,7 @@ buf_LRU_stat_update(void)
|
|||||||
/*=====================*/
|
/*=====================*/
|
||||||
{
|
{
|
||||||
buf_LRU_stat_t* item;
|
buf_LRU_stat_t* item;
|
||||||
|
buf_LRU_stat_t cur_stat;
|
||||||
|
|
||||||
/* If we haven't started eviction yet then don't update stats. */
|
/* If we haven't started eviction yet then don't update stats. */
|
||||||
if (buf_pool->freed_page_clock == 0) {
|
if (buf_pool->freed_page_clock == 0) {
|
||||||
@ -1955,12 +1956,19 @@ buf_LRU_stat_update(void)
|
|||||||
buf_LRU_stat_arr_ind++;
|
buf_LRU_stat_arr_ind++;
|
||||||
buf_LRU_stat_arr_ind %= BUF_LRU_STAT_N_INTERVAL;
|
buf_LRU_stat_arr_ind %= BUF_LRU_STAT_N_INTERVAL;
|
||||||
|
|
||||||
/* Add the current value and subtract the obsolete entry. */
|
/* Add the current value and subtract the obsolete entry.
|
||||||
buf_LRU_stat_sum.io += buf_LRU_stat_cur.io - item->io;
|
Since buf_LRU_stat_cur is not protected by any mutex,
|
||||||
buf_LRU_stat_sum.unzip += buf_LRU_stat_cur.unzip - item->unzip;
|
it can be changing between adding to buf_LRU_stat_sum
|
||||||
|
and copying to item. Assign it to local variables to make
|
||||||
|
sure the same value assign to the buf_LRU_stat_sum
|
||||||
|
and item */
|
||||||
|
cur_stat = buf_LRU_stat_cur;
|
||||||
|
|
||||||
|
buf_LRU_stat_sum.io += cur_stat.io - item->io;
|
||||||
|
buf_LRU_stat_sum.unzip += cur_stat.unzip - item->unzip;
|
||||||
|
|
||||||
/* Put current entry in the array. */
|
/* Put current entry in the array. */
|
||||||
memcpy(item, &buf_LRU_stat_cur, sizeof *item);
|
memcpy(item, &cur_stat, sizeof *item);
|
||||||
|
|
||||||
buf_pool_mutex_exit();
|
buf_pool_mutex_exit();
|
||||||
|
|
||||||
|
@ -2688,7 +2688,7 @@ dict_scan_to(
|
|||||||
quote = '\0';
|
quote = '\0';
|
||||||
} else if (quote) {
|
} else if (quote) {
|
||||||
/* Within quotes: do nothing. */
|
/* Within quotes: do nothing. */
|
||||||
} else if (*ptr == '`' || *ptr == '"') {
|
} else if (*ptr == '`' || *ptr == '"' || *ptr == '\'') {
|
||||||
/* Starting quote: remember the quote character. */
|
/* Starting quote: remember the quote character. */
|
||||||
quote = *ptr;
|
quote = *ptr;
|
||||||
} else {
|
} else {
|
||||||
|
@ -3326,7 +3326,7 @@ fseg_free_page_low(
|
|||||||
"InnoDB: database!\n", (ulong) page);
|
"InnoDB: database!\n", (ulong) page);
|
||||||
crash:
|
crash:
|
||||||
fputs("InnoDB: Please refer to\n"
|
fputs("InnoDB: Please refer to\n"
|
||||||
"InnoDB: " REFMAN "forcing-recovery.html\n"
|
"InnoDB: " REFMAN "forcing-innodb-recovery.html\n"
|
||||||
"InnoDB: about forcing recovery.\n", stderr);
|
"InnoDB: about forcing recovery.\n", stderr);
|
||||||
ut_error;
|
ut_error;
|
||||||
}
|
}
|
||||||
|
@ -6293,10 +6293,11 @@ create_clustered_index_when_no_primary(
|
|||||||
/*****************************************************************//**
|
/*****************************************************************//**
|
||||||
Return a display name for the row format
|
Return a display name for the row format
|
||||||
@return row format name */
|
@return row format name */
|
||||||
|
UNIV_INTERN
|
||||||
const char *get_row_format_name(
|
const char*
|
||||||
/*============================*/
|
get_row_format_name(
|
||||||
enum row_type row_format) /*!< in: Row Format */
|
/*================*/
|
||||||
|
enum row_type row_format) /*!< in: Row Format */
|
||||||
{
|
{
|
||||||
switch (row_format) {
|
switch (row_format) {
|
||||||
case ROW_TYPE_COMPACT:
|
case ROW_TYPE_COMPACT:
|
||||||
@ -6311,12 +6312,38 @@ enum row_type row_format) /*!< in: Row Format */
|
|||||||
return("DEFAULT");
|
return("DEFAULT");
|
||||||
case ROW_TYPE_FIXED:
|
case ROW_TYPE_FIXED:
|
||||||
return("FIXED");
|
return("FIXED");
|
||||||
default:
|
case ROW_TYPE_PAGE:
|
||||||
|
case ROW_TYPE_NOT_USED:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return("NOT USED");
|
return("NOT USED");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** If file-per-table is missing, issue warning and set ret false */
|
||||||
|
#define CHECK_ERROR_ROW_TYPE_NEEDS_FILE_PER_TABLE \
|
||||||
|
if (!srv_file_per_table) { \
|
||||||
|
push_warning_printf( \
|
||||||
|
thd, MYSQL_ERROR::WARN_LEVEL_WARN, \
|
||||||
|
ER_ILLEGAL_HA_CREATE_OPTION, \
|
||||||
|
"InnoDB: ROW_FORMAT=%s requires" \
|
||||||
|
" innodb_file_per_table.", \
|
||||||
|
get_row_format_name(row_format)); \
|
||||||
|
ret = FALSE; \
|
||||||
|
}
|
||||||
|
|
||||||
|
/** If file-format is Antelope, issue warning and set ret false */
|
||||||
|
#define CHECK_ERROR_ROW_TYPE_NEEDS_GT_ANTELOPE \
|
||||||
|
if (srv_file_format < DICT_TF_FORMAT_ZIP) { \
|
||||||
|
push_warning_printf( \
|
||||||
|
thd, MYSQL_ERROR::WARN_LEVEL_WARN, \
|
||||||
|
ER_ILLEGAL_HA_CREATE_OPTION, \
|
||||||
|
"InnoDB: ROW_FORMAT=%s requires" \
|
||||||
|
" innodb_file_format > Antelope.", \
|
||||||
|
get_row_format_name(row_format)); \
|
||||||
|
ret = FALSE; \
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*****************************************************************//**
|
/*****************************************************************//**
|
||||||
Validates the create options. We may build on this function
|
Validates the create options. We may build on this function
|
||||||
in future. For now, it checks two specifiers:
|
in future. For now, it checks two specifiers:
|
||||||
@ -6334,7 +6361,7 @@ create_options_are_valid(
|
|||||||
{
|
{
|
||||||
ibool kbs_specified = FALSE;
|
ibool kbs_specified = FALSE;
|
||||||
ibool ret = TRUE;
|
ibool ret = TRUE;
|
||||||
enum row_type row_type = form->s->row_type;
|
enum row_type row_format = form->s->row_type;
|
||||||
|
|
||||||
ut_ad(thd != NULL);
|
ut_ad(thd != NULL);
|
||||||
|
|
||||||
@ -6343,23 +6370,6 @@ create_options_are_valid(
|
|||||||
return(TRUE);
|
return(TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check for a valid Innodb ROW_FORMAT specifier. For example,
|
|
||||||
ROW_TYPE_FIXED can be sent to Innodb */
|
|
||||||
switch (row_type) {
|
|
||||||
case ROW_TYPE_COMPACT:
|
|
||||||
case ROW_TYPE_COMPRESSED:
|
|
||||||
case ROW_TYPE_DYNAMIC:
|
|
||||||
case ROW_TYPE_REDUNDANT:
|
|
||||||
case ROW_TYPE_DEFAULT:
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
push_warning(
|
|
||||||
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
|
||||||
ER_ILLEGAL_HA_CREATE_OPTION,
|
|
||||||
"InnoDB: invalid ROW_FORMAT specifier.");
|
|
||||||
ret = FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
ut_ad(form != NULL);
|
ut_ad(form != NULL);
|
||||||
ut_ad(create_info != NULL);
|
ut_ad(create_info != NULL);
|
||||||
|
|
||||||
@ -6372,7 +6382,23 @@ create_options_are_valid(
|
|||||||
case 4:
|
case 4:
|
||||||
case 8:
|
case 8:
|
||||||
case 16:
|
case 16:
|
||||||
/* Valid value. */
|
/* Valid KEY_BLOCK_SIZE, check its dependencies. */
|
||||||
|
if (!srv_file_per_table) {
|
||||||
|
push_warning(
|
||||||
|
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
||||||
|
ER_ILLEGAL_HA_CREATE_OPTION,
|
||||||
|
"InnoDB: KEY_BLOCK_SIZE requires"
|
||||||
|
" innodb_file_per_table.");
|
||||||
|
ret = FALSE;
|
||||||
|
}
|
||||||
|
if (srv_file_format < DICT_TF_FORMAT_ZIP) {
|
||||||
|
push_warning(
|
||||||
|
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
||||||
|
ER_ILLEGAL_HA_CREATE_OPTION,
|
||||||
|
"InnoDB: KEY_BLOCK_SIZE requires"
|
||||||
|
" innodb_file_format > Antelope.");
|
||||||
|
ret = FALSE;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
push_warning_printf(
|
push_warning_printf(
|
||||||
@ -6382,72 +6408,43 @@ create_options_are_valid(
|
|||||||
" Valid values are [1, 2, 4, 8, 16]",
|
" Valid values are [1, 2, 4, 8, 16]",
|
||||||
create_info->key_block_size);
|
create_info->key_block_size);
|
||||||
ret = FALSE;
|
ret = FALSE;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If KEY_BLOCK_SIZE was specified, check for its
|
/* Check for a valid Innodb ROW_FORMAT specifier and
|
||||||
dependencies. */
|
other incompatibilities. */
|
||||||
if (kbs_specified && !srv_file_per_table) {
|
switch (row_format) {
|
||||||
push_warning(
|
|
||||||
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
|
||||||
ER_ILLEGAL_HA_CREATE_OPTION,
|
|
||||||
"InnoDB: KEY_BLOCK_SIZE"
|
|
||||||
" requires innodb_file_per_table.");
|
|
||||||
ret = FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (kbs_specified && srv_file_format < DICT_TF_FORMAT_ZIP) {
|
|
||||||
push_warning(
|
|
||||||
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
|
||||||
ER_ILLEGAL_HA_CREATE_OPTION,
|
|
||||||
"InnoDB: KEY_BLOCK_SIZE requires"
|
|
||||||
" innodb_file_format > Antelope.");
|
|
||||||
ret = FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (row_type) {
|
|
||||||
case ROW_TYPE_COMPRESSED:
|
case ROW_TYPE_COMPRESSED:
|
||||||
case ROW_TYPE_DYNAMIC:
|
CHECK_ERROR_ROW_TYPE_NEEDS_FILE_PER_TABLE;
|
||||||
/* These two ROW_FORMATs require srv_file_per_table
|
CHECK_ERROR_ROW_TYPE_NEEDS_GT_ANTELOPE;
|
||||||
and srv_file_format > Antelope */
|
|
||||||
if (!srv_file_per_table) {
|
|
||||||
push_warning_printf(
|
|
||||||
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
|
||||||
ER_ILLEGAL_HA_CREATE_OPTION,
|
|
||||||
"InnoDB: ROW_FORMAT=%s"
|
|
||||||
" requires innodb_file_per_table.",
|
|
||||||
get_row_format_name(row_type));
|
|
||||||
ret = FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (srv_file_format < DICT_TF_FORMAT_ZIP) {
|
|
||||||
push_warning_printf(
|
|
||||||
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
|
||||||
ER_ILLEGAL_HA_CREATE_OPTION,
|
|
||||||
"InnoDB: ROW_FORMAT=%s requires"
|
|
||||||
" innodb_file_format > Antelope.",
|
|
||||||
get_row_format_name(row_type));
|
|
||||||
ret = FALSE;
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
|
||||||
switch (row_type) {
|
|
||||||
case ROW_TYPE_REDUNDANT:
|
|
||||||
case ROW_TYPE_COMPACT:
|
|
||||||
case ROW_TYPE_DYNAMIC:
|
case ROW_TYPE_DYNAMIC:
|
||||||
/* KEY_BLOCK_SIZE is only allowed with Compressed or Default */
|
CHECK_ERROR_ROW_TYPE_NEEDS_FILE_PER_TABLE;
|
||||||
|
CHECK_ERROR_ROW_TYPE_NEEDS_GT_ANTELOPE;
|
||||||
|
/* fall through since dynamic also shuns KBS */
|
||||||
|
case ROW_TYPE_COMPACT:
|
||||||
|
case ROW_TYPE_REDUNDANT:
|
||||||
if (kbs_specified) {
|
if (kbs_specified) {
|
||||||
push_warning_printf(
|
push_warning_printf(
|
||||||
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
||||||
ER_ILLEGAL_HA_CREATE_OPTION,
|
ER_ILLEGAL_HA_CREATE_OPTION,
|
||||||
"InnoDB: cannot specify ROW_FORMAT = %s"
|
"InnoDB: cannot specify ROW_FORMAT = %s"
|
||||||
" with KEY_BLOCK_SIZE.",
|
" with KEY_BLOCK_SIZE.",
|
||||||
get_row_format_name(row_type));
|
get_row_format_name(row_format));
|
||||||
ret = FALSE;
|
ret = FALSE;
|
||||||
}
|
}
|
||||||
default:
|
break;
|
||||||
|
case ROW_TYPE_DEFAULT:
|
||||||
|
break;
|
||||||
|
case ROW_TYPE_FIXED:
|
||||||
|
case ROW_TYPE_PAGE:
|
||||||
|
case ROW_TYPE_NOT_USED:
|
||||||
|
push_warning(
|
||||||
|
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
||||||
|
ER_ILLEGAL_HA_CREATE_OPTION, \
|
||||||
|
"InnoDB: invalid ROW_FORMAT specifier.");
|
||||||
|
ret = FALSE;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -6498,7 +6495,7 @@ ha_innobase::create(
|
|||||||
const ulint file_format = srv_file_format;
|
const ulint file_format = srv_file_format;
|
||||||
const char* stmt;
|
const char* stmt;
|
||||||
size_t stmt_len;
|
size_t stmt_len;
|
||||||
enum row_type row_type;
|
enum row_type row_format;
|
||||||
|
|
||||||
DBUG_ENTER("ha_innobase::create");
|
DBUG_ENTER("ha_innobase::create");
|
||||||
|
|
||||||
@ -6598,8 +6595,8 @@ ha_innobase::create(
|
|||||||
push_warning(
|
push_warning(
|
||||||
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
||||||
ER_ILLEGAL_HA_CREATE_OPTION,
|
ER_ILLEGAL_HA_CREATE_OPTION,
|
||||||
"InnoDB: KEY_BLOCK_SIZE"
|
"InnoDB: KEY_BLOCK_SIZE requires"
|
||||||
" requires innodb_file_per_table.");
|
" innodb_file_per_table.");
|
||||||
flags = 0;
|
flags = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -6616,20 +6613,19 @@ ha_innobase::create(
|
|||||||
push_warning_printf(
|
push_warning_printf(
|
||||||
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
||||||
ER_ILLEGAL_HA_CREATE_OPTION,
|
ER_ILLEGAL_HA_CREATE_OPTION,
|
||||||
"InnoDB: ignoring"
|
"InnoDB: ignoring KEY_BLOCK_SIZE=%lu.",
|
||||||
" KEY_BLOCK_SIZE=%lu.",
|
|
||||||
create_info->key_block_size);
|
create_info->key_block_size);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
row_type = form->s->row_type;
|
row_format = form->s->row_type;
|
||||||
|
|
||||||
if (flags) {
|
if (flags) {
|
||||||
/* if ROW_FORMAT is set to default,
|
/* if ROW_FORMAT is set to default,
|
||||||
automatically change it to COMPRESSED.*/
|
automatically change it to COMPRESSED.*/
|
||||||
if (row_type == ROW_TYPE_DEFAULT) {
|
if (row_format == ROW_TYPE_DEFAULT) {
|
||||||
row_type = ROW_TYPE_COMPRESSED;
|
row_format = ROW_TYPE_COMPRESSED;
|
||||||
} else if (row_type != ROW_TYPE_COMPRESSED) {
|
} else if (row_format != ROW_TYPE_COMPRESSED) {
|
||||||
/* ROW_FORMAT other than COMPRESSED
|
/* ROW_FORMAT other than COMPRESSED
|
||||||
ignores KEY_BLOCK_SIZE. It does not
|
ignores KEY_BLOCK_SIZE. It does not
|
||||||
make sense to reject conflicting
|
make sense to reject conflicting
|
||||||
@ -6646,7 +6642,7 @@ ha_innobase::create(
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
/* flags == 0 means no KEY_BLOCK_SIZE.*/
|
/* flags == 0 means no KEY_BLOCK_SIZE.*/
|
||||||
if (row_type == ROW_TYPE_COMPRESSED) {
|
if (row_format == ROW_TYPE_COMPRESSED) {
|
||||||
/* ROW_FORMAT=COMPRESSED without
|
/* ROW_FORMAT=COMPRESSED without
|
||||||
KEY_BLOCK_SIZE implies half the
|
KEY_BLOCK_SIZE implies half the
|
||||||
maximum KEY_BLOCK_SIZE. */
|
maximum KEY_BLOCK_SIZE. */
|
||||||
@ -6661,7 +6657,7 @@ ha_innobase::create(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (row_type) {
|
switch (row_format) {
|
||||||
case ROW_TYPE_REDUNDANT:
|
case ROW_TYPE_REDUNDANT:
|
||||||
break;
|
break;
|
||||||
case ROW_TYPE_COMPRESSED:
|
case ROW_TYPE_COMPRESSED:
|
||||||
@ -6672,25 +6668,25 @@ ha_innobase::create(
|
|||||||
ER_ILLEGAL_HA_CREATE_OPTION,
|
ER_ILLEGAL_HA_CREATE_OPTION,
|
||||||
"InnoDB: ROW_FORMAT=%s requires"
|
"InnoDB: ROW_FORMAT=%s requires"
|
||||||
" innodb_file_per_table.",
|
" innodb_file_per_table.",
|
||||||
get_row_format_name(row_type));
|
get_row_format_name(row_format));
|
||||||
} else if (file_format < DICT_TF_FORMAT_ZIP) {
|
} else if (file_format < DICT_TF_FORMAT_ZIP) {
|
||||||
push_warning_printf(
|
push_warning_printf(
|
||||||
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
||||||
ER_ILLEGAL_HA_CREATE_OPTION,
|
ER_ILLEGAL_HA_CREATE_OPTION,
|
||||||
"InnoDB: ROW_FORMAT=%s requires"
|
"InnoDB: ROW_FORMAT=%s requires"
|
||||||
" innodb_file_format > Antelope.",
|
" innodb_file_format > Antelope.",
|
||||||
get_row_format_name(row_type));
|
get_row_format_name(row_format));
|
||||||
} else {
|
} else {
|
||||||
flags |= DICT_TF_COMPACT
|
flags |= DICT_TF_COMPACT
|
||||||
| (DICT_TF_FORMAT_ZIP
|
| (DICT_TF_FORMAT_ZIP
|
||||||
<< DICT_TF_FORMAT_SHIFT);
|
<< DICT_TF_FORMAT_SHIFT);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* fall through */
|
/* fall through */
|
||||||
case ROW_TYPE_NOT_USED:
|
case ROW_TYPE_NOT_USED:
|
||||||
case ROW_TYPE_FIXED:
|
case ROW_TYPE_FIXED:
|
||||||
default:
|
case ROW_TYPE_PAGE:
|
||||||
push_warning(
|
push_warning(
|
||||||
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
||||||
ER_ILLEGAL_HA_CREATE_OPTION,
|
ER_ILLEGAL_HA_CREATE_OPTION,
|
||||||
@ -6808,23 +6804,25 @@ ha_innobase::create(
|
|||||||
setup at this stage and so we use thd. */
|
setup at this stage and so we use thd. */
|
||||||
|
|
||||||
/* We need to copy the AUTOINC value from the old table if
|
/* We need to copy the AUTOINC value from the old table if
|
||||||
this is an ALTER TABLE or CREATE INDEX because CREATE INDEX
|
this is an ALTER|OPTIMIZE TABLE or CREATE INDEX because CREATE INDEX
|
||||||
does a table copy too. */
|
does a table copy too. If query was one of :
|
||||||
|
|
||||||
|
CREATE TABLE ...AUTO_INCREMENT = x; or
|
||||||
|
ALTER TABLE...AUTO_INCREMENT = x; or
|
||||||
|
OPTIMIZE TABLE t; or
|
||||||
|
CREATE INDEX x on t(...);
|
||||||
|
|
||||||
|
Find out a table definition from the dictionary and get
|
||||||
|
the current value of the auto increment field. Set a new
|
||||||
|
value to the auto increment field if the value is greater
|
||||||
|
than the maximum value in the column. */
|
||||||
|
|
||||||
if (((create_info->used_fields & HA_CREATE_USED_AUTO)
|
if (((create_info->used_fields & HA_CREATE_USED_AUTO)
|
||||||
|| thd_sql_command(thd) == SQLCOM_ALTER_TABLE
|
|| thd_sql_command(thd) == SQLCOM_ALTER_TABLE
|
||||||
|
|| thd_sql_command(thd) == SQLCOM_OPTIMIZE
|
||||||
|| thd_sql_command(thd) == SQLCOM_CREATE_INDEX)
|
|| thd_sql_command(thd) == SQLCOM_CREATE_INDEX)
|
||||||
&& create_info->auto_increment_value > 0) {
|
&& create_info->auto_increment_value > 0) {
|
||||||
|
|
||||||
/* Query was one of :
|
|
||||||
CREATE TABLE ...AUTO_INCREMENT = x; or
|
|
||||||
ALTER TABLE...AUTO_INCREMENT = x; or
|
|
||||||
CREATE INDEX x on t(...);
|
|
||||||
Find out a table definition from the dictionary and get
|
|
||||||
the current value of the auto increment field. Set a new
|
|
||||||
value to the auto increment field if the value is greater
|
|
||||||
than the maximum value in the column. */
|
|
||||||
|
|
||||||
auto_inc_value = create_info->auto_increment_value;
|
auto_inc_value = create_info->auto_increment_value;
|
||||||
|
|
||||||
dict_table_autoinc_lock(innobase_table);
|
dict_table_autoinc_lock(innobase_table);
|
||||||
|
@ -371,8 +371,16 @@ fill_innodb_trx_from_cache(
|
|||||||
row->trx_mysql_thread_id));
|
row->trx_mysql_thread_id));
|
||||||
|
|
||||||
/* trx_query */
|
/* trx_query */
|
||||||
OK(field_store_string(fields[IDX_TRX_QUERY],
|
if (row->trx_query) {
|
||||||
row->trx_query));
|
/* store will do appropriate character set
|
||||||
|
conversion check */
|
||||||
|
fields[IDX_TRX_QUERY]->store(
|
||||||
|
row->trx_query, strlen(row->trx_query),
|
||||||
|
row->trx_query_cs);
|
||||||
|
fields[IDX_TRX_QUERY]->set_notnull();
|
||||||
|
} else {
|
||||||
|
fields[IDX_TRX_QUERY]->set_null();
|
||||||
|
}
|
||||||
|
|
||||||
OK(schema_table_store_record(thd, table));
|
OK(schema_table_store_record(thd, table));
|
||||||
}
|
}
|
||||||
|
@ -332,10 +332,14 @@ ulint
|
|||||||
btr_cur_del_mark_set_clust_rec(
|
btr_cur_del_mark_set_clust_rec(
|
||||||
/*===========================*/
|
/*===========================*/
|
||||||
ulint flags, /*!< in: undo logging and locking flags */
|
ulint flags, /*!< in: undo logging and locking flags */
|
||||||
btr_cur_t* cursor, /*!< in: cursor */
|
buf_block_t* block, /*!< in/out: buffer block of the record */
|
||||||
|
rec_t* rec, /*!< in/out: record */
|
||||||
|
dict_index_t* index, /*!< in: clustered index of the record */
|
||||||
|
const ulint* offsets,/*!< in: rec_get_offsets(rec) */
|
||||||
ibool val, /*!< in: value to set */
|
ibool val, /*!< in: value to set */
|
||||||
que_thr_t* thr, /*!< in: query thread */
|
que_thr_t* thr, /*!< in: query thread */
|
||||||
mtr_t* mtr); /*!< in: mtr */
|
mtr_t* mtr) /*!< in: mtr */
|
||||||
|
__attribute__((nonnull));
|
||||||
/***********************************************************//**
|
/***********************************************************//**
|
||||||
Sets a secondary index record delete mark to TRUE or FALSE.
|
Sets a secondary index record delete mark to TRUE or FALSE.
|
||||||
@return DB_SUCCESS, DB_LOCK_WAIT, or error number */
|
@return DB_SUCCESS, DB_LOCK_WAIT, or error number */
|
||||||
@ -481,40 +485,22 @@ btr_estimate_number_of_different_key_vals(
|
|||||||
/*======================================*/
|
/*======================================*/
|
||||||
dict_index_t* index); /*!< in: index */
|
dict_index_t* index); /*!< in: index */
|
||||||
/*******************************************************************//**
|
/*******************************************************************//**
|
||||||
Marks not updated extern fields as not-owned by this record. The ownership
|
Marks non-updated off-page fields as disowned by this record. The ownership
|
||||||
is transferred to the updated record which is inserted elsewhere in the
|
must be transferred to the updated record which is inserted elsewhere in the
|
||||||
index tree. In purge only the owner of externally stored field is allowed
|
index tree. In purge only the owner of externally stored field is allowed
|
||||||
to free the field.
|
to free the field. */
|
||||||
@return TRUE if BLOB ownership was transferred */
|
|
||||||
UNIV_INTERN
|
UNIV_INTERN
|
||||||
ibool
|
void
|
||||||
btr_cur_mark_extern_inherited_fields(
|
btr_cur_disown_inherited_fields(
|
||||||
/*=================================*/
|
/*============================*/
|
||||||
page_zip_des_t* page_zip,/*!< in/out: compressed page whose uncompressed
|
page_zip_des_t* page_zip,/*!< in/out: compressed page whose uncompressed
|
||||||
part will be updated, or NULL */
|
part will be updated, or NULL */
|
||||||
rec_t* rec, /*!< in/out: record in a clustered index */
|
rec_t* rec, /*!< in/out: record in a clustered index */
|
||||||
dict_index_t* index, /*!< in: index of the page */
|
dict_index_t* index, /*!< in: index of the page */
|
||||||
const ulint* offsets,/*!< in: array returned by rec_get_offsets() */
|
const ulint* offsets,/*!< in: array returned by rec_get_offsets() */
|
||||||
const upd_t* update, /*!< in: update vector */
|
const upd_t* update, /*!< in: update vector */
|
||||||
mtr_t* mtr); /*!< in: mtr, or NULL if not logged */
|
mtr_t* mtr) /*!< in/out: mini-transaction */
|
||||||
/*******************************************************************//**
|
__attribute__((nonnull(2,3,4,5,6)));
|
||||||
The complement of the previous function: in an update entry may inherit
|
|
||||||
some externally stored fields from a record. We must mark them as inherited
|
|
||||||
in entry, so that they are not freed in a rollback. */
|
|
||||||
UNIV_INTERN
|
|
||||||
void
|
|
||||||
btr_cur_mark_dtuple_inherited_extern(
|
|
||||||
/*=================================*/
|
|
||||||
dtuple_t* entry, /*!< in/out: updated entry to be
|
|
||||||
inserted to clustered index */
|
|
||||||
const upd_t* update); /*!< in: update vector */
|
|
||||||
/*******************************************************************//**
|
|
||||||
Marks all extern fields in a dtuple as owned by the record. */
|
|
||||||
UNIV_INTERN
|
|
||||||
void
|
|
||||||
btr_cur_unmark_dtuple_extern_fields(
|
|
||||||
/*================================*/
|
|
||||||
dtuple_t* entry); /*!< in/out: clustered index entry */
|
|
||||||
/*******************************************************************//**
|
/*******************************************************************//**
|
||||||
Stores the fields in big_rec_vec to the tablespace and puts pointers to
|
Stores the fields in big_rec_vec to the tablespace and puts pointers to
|
||||||
them in rec. The extern flags in rec will have to be set beforehand.
|
them in rec. The extern flags in rec will have to be set beforehand.
|
||||||
|
@ -154,14 +154,19 @@ dfield_dup(
|
|||||||
dfield_t* field, /*!< in/out: data field */
|
dfield_t* field, /*!< in/out: data field */
|
||||||
mem_heap_t* heap); /*!< in: memory heap where allocated */
|
mem_heap_t* heap); /*!< in: memory heap where allocated */
|
||||||
/*********************************************************************//**
|
/*********************************************************************//**
|
||||||
Tests if data length and content is equal for two dfields.
|
Tests if two data fields are equal.
|
||||||
@return TRUE if equal */
|
If len==0, tests the data length and content for equality.
|
||||||
|
If len>0, tests the first len bytes of the content for equality.
|
||||||
|
@return TRUE if both fields are NULL or if they are equal */
|
||||||
UNIV_INLINE
|
UNIV_INLINE
|
||||||
ibool
|
ibool
|
||||||
dfield_datas_are_binary_equal(
|
dfield_datas_are_binary_equal(
|
||||||
/*==========================*/
|
/*==========================*/
|
||||||
const dfield_t* field1, /*!< in: field */
|
const dfield_t* field1, /*!< in: field */
|
||||||
const dfield_t* field2);/*!< in: field */
|
const dfield_t* field2, /*!< in: field */
|
||||||
|
ulint len) /*!< in: maximum prefix to compare,
|
||||||
|
or 0 to compare the whole field length */
|
||||||
|
__attribute__((nonnull, warn_unused_result));
|
||||||
/*********************************************************************//**
|
/*********************************************************************//**
|
||||||
Tests if dfield data length and content is equal to the given.
|
Tests if dfield data length and content is equal to the given.
|
||||||
@return TRUE if equal */
|
@return TRUE if equal */
|
||||||
|
@ -229,20 +229,30 @@ dfield_dup(
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*********************************************************************//**
|
/*********************************************************************//**
|
||||||
Tests if data length and content is equal for two dfields.
|
Tests if two data fields are equal.
|
||||||
@return TRUE if equal */
|
If len==0, tests the data length and content for equality.
|
||||||
|
If len>0, tests the first len bytes of the content for equality.
|
||||||
|
@return TRUE if both fields are NULL or if they are equal */
|
||||||
UNIV_INLINE
|
UNIV_INLINE
|
||||||
ibool
|
ibool
|
||||||
dfield_datas_are_binary_equal(
|
dfield_datas_are_binary_equal(
|
||||||
/*==========================*/
|
/*==========================*/
|
||||||
const dfield_t* field1, /*!< in: field */
|
const dfield_t* field1, /*!< in: field */
|
||||||
const dfield_t* field2) /*!< in: field */
|
const dfield_t* field2, /*!< in: field */
|
||||||
|
ulint len) /*!< in: maximum prefix to compare,
|
||||||
|
or 0 to compare the whole field length */
|
||||||
{
|
{
|
||||||
ulint len;
|
ulint len2 = len;
|
||||||
|
|
||||||
len = field1->len;
|
if (field1->len == UNIV_SQL_NULL || len == 0 || field1->len < len) {
|
||||||
|
len = field1->len;
|
||||||
|
}
|
||||||
|
|
||||||
return(len == field2->len
|
if (field2->len == UNIV_SQL_NULL || len2 == 0 || field2->len < len2) {
|
||||||
|
len2 = field2->len;
|
||||||
|
}
|
||||||
|
|
||||||
|
return(len == len2
|
||||||
&& (len == UNIV_SQL_NULL
|
&& (len == UNIV_SQL_NULL
|
||||||
|| !memcmp(field1->data, field2->data, len)));
|
|| !memcmp(field1->data, field2->data, len)));
|
||||||
}
|
}
|
||||||
|
@ -286,10 +286,13 @@ row_upd_changes_ord_field_binary(
|
|||||||
row and the data values in update are not
|
row and the data values in update are not
|
||||||
known when this function is called, e.g., at
|
known when this function is called, e.g., at
|
||||||
compile time */
|
compile time */
|
||||||
|
const row_ext_t*ext, /*!< NULL, or prefixes of the externally
|
||||||
|
stored columns in the old row */
|
||||||
dict_index_t* index, /*!< in: index of the record */
|
dict_index_t* index, /*!< in: index of the record */
|
||||||
const upd_t* update);/*!< in: update vector for the row; NOTE: the
|
const upd_t* update) /*!< in: update vector for the row; NOTE: the
|
||||||
field numbers in this MUST be clustered index
|
field numbers in this MUST be clustered index
|
||||||
positions! */
|
positions! */
|
||||||
|
__attribute__((nonnull(3,4), warn_unused_result));
|
||||||
/***********************************************************//**
|
/***********************************************************//**
|
||||||
Checks if an update vector changes an ordering field of an index record.
|
Checks if an update vector changes an ordering field of an index record.
|
||||||
This function is fast if the update vector is short or the number of ordering
|
This function is fast if the update vector is short or the number of ordering
|
||||||
@ -462,11 +465,16 @@ struct upd_node_struct{
|
|||||||
#define UPD_NODE_INSERT_CLUSTERED 3 /* clustered index record should be
|
#define UPD_NODE_INSERT_CLUSTERED 3 /* clustered index record should be
|
||||||
inserted, old record is already delete
|
inserted, old record is already delete
|
||||||
marked */
|
marked */
|
||||||
#define UPD_NODE_UPDATE_ALL_SEC 4 /* an ordering field of the clustered
|
#define UPD_NODE_INSERT_BLOB 4 /* clustered index record should be
|
||||||
|
inserted, old record is already
|
||||||
|
delete-marked; non-updated BLOBs
|
||||||
|
should be inherited by the new record
|
||||||
|
and disowned by the old record */
|
||||||
|
#define UPD_NODE_UPDATE_ALL_SEC 5 /* an ordering field of the clustered
|
||||||
index record was changed, or this is
|
index record was changed, or this is
|
||||||
a delete operation: should update
|
a delete operation: should update
|
||||||
all the secondary index records */
|
all the secondary index records */
|
||||||
#define UPD_NODE_UPDATE_SOME_SEC 5 /* secondary index entries should be
|
#define UPD_NODE_UPDATE_SOME_SEC 6 /* secondary index entries should be
|
||||||
looked at and updated if an ordering
|
looked at and updated if an ordering
|
||||||
field changed */
|
field changed */
|
||||||
|
|
||||||
|
@ -110,6 +110,8 @@ struct i_s_trx_row_struct {
|
|||||||
/*!< thd_get_thread_id() */
|
/*!< thd_get_thread_id() */
|
||||||
const char* trx_query; /*!< MySQL statement being
|
const char* trx_query; /*!< MySQL statement being
|
||||||
executed in the transaction */
|
executed in the transaction */
|
||||||
|
struct charset_info_st* trx_query_cs; /*!< charset encode the MySQL
|
||||||
|
statement */
|
||||||
};
|
};
|
||||||
|
|
||||||
/** This structure represents INFORMATION_SCHEMA.innodb_lock_waits row */
|
/** This structure represents INFORMATION_SCHEMA.innodb_lock_waits row */
|
||||||
|
@ -46,7 +46,7 @@ Created 1/20/1994 Heikki Tuuri
|
|||||||
|
|
||||||
#define INNODB_VERSION_MAJOR 1
|
#define INNODB_VERSION_MAJOR 1
|
||||||
#define INNODB_VERSION_MINOR 0
|
#define INNODB_VERSION_MINOR 0
|
||||||
#define INNODB_VERSION_BUGFIX 14
|
#define INNODB_VERSION_BUGFIX 15
|
||||||
|
|
||||||
/* The following is the InnoDB version as shown in
|
/* The following is the InnoDB version as shown in
|
||||||
SELECT plugin_version FROM information_schema.plugins;
|
SELECT plugin_version FROM information_schema.plugins;
|
||||||
|
@ -2188,7 +2188,7 @@ recv_report_corrupt_log(
|
|||||||
"InnoDB: far enough in recovery! Please run CHECK TABLE\n"
|
"InnoDB: far enough in recovery! Please run CHECK TABLE\n"
|
||||||
"InnoDB: on your InnoDB tables to check that they are ok!\n"
|
"InnoDB: on your InnoDB tables to check that they are ok!\n"
|
||||||
"InnoDB: If mysqld crashes after this recovery, look at\n"
|
"InnoDB: If mysqld crashes after this recovery, look at\n"
|
||||||
"InnoDB: " REFMAN "forcing-recovery.html\n"
|
"InnoDB: " REFMAN "forcing-innodb-recovery.html\n"
|
||||||
"InnoDB: about forcing recovery.\n", stderr);
|
"InnoDB: about forcing recovery.\n", stderr);
|
||||||
|
|
||||||
fflush(stderr);
|
fflush(stderr);
|
||||||
|
@ -17,6 +17,9 @@
|
|||||||
MYSQL_STORAGE_ENGINE(innodb_plugin,, [InnoDB Storage Engine],
|
MYSQL_STORAGE_ENGINE(innodb_plugin,, [InnoDB Storage Engine],
|
||||||
[Transactional Tables using InnoDB], [max,max-no-ndb])
|
[Transactional Tables using InnoDB], [max,max-no-ndb])
|
||||||
MYSQL_PLUGIN_DIRECTORY(innodb_plugin, [storage/innodb_plugin])
|
MYSQL_PLUGIN_DIRECTORY(innodb_plugin, [storage/innodb_plugin])
|
||||||
|
# Enable if you know what you are doing (trying to link both InnoDB and
|
||||||
|
# InnoDB Plugin statically into MySQL does not work).
|
||||||
|
#MYSQL_PLUGIN_STATIC(innodb_plugin, [libinnobase.a])
|
||||||
MYSQL_PLUGIN_DYNAMIC(innodb_plugin, [ha_innodb_plugin.la])
|
MYSQL_PLUGIN_DYNAMIC(innodb_plugin, [ha_innodb_plugin.la])
|
||||||
MYSQL_PLUGIN_ACTIONS(innodb_plugin, [
|
MYSQL_PLUGIN_ACTIONS(innodb_plugin, [
|
||||||
AC_CHECK_HEADERS(sched.h)
|
AC_CHECK_HEADERS(sched.h)
|
||||||
@ -136,17 +139,24 @@ MYSQL_PLUGIN_ACTIONS(innodb_plugin, [
|
|||||||
)
|
)
|
||||||
|
|
||||||
AC_MSG_CHECKING(whether Solaris libc atomic functions are available)
|
AC_MSG_CHECKING(whether Solaris libc atomic functions are available)
|
||||||
# either define HAVE_IB_SOLARIS_ATOMICS or not
|
# Define HAVE_IB_SOLARIS_ATOMICS if _all_ of the following
|
||||||
AC_CHECK_FUNCS(atomic_cas_ulong \
|
# functions are present.
|
||||||
|
AC_CHECK_FUNCS(atomic_add_long_nv \
|
||||||
atomic_cas_32 \
|
atomic_cas_32 \
|
||||||
atomic_cas_64 \
|
atomic_cas_64 \
|
||||||
atomic_add_long_nv \
|
atomic_cas_ulong \
|
||||||
atomic_swap_uchar,
|
atomic_swap_uchar)
|
||||||
|
|
||||||
AC_DEFINE([HAVE_IB_SOLARIS_ATOMICS], [1],
|
if test "${ac_cv_func_atomic_add_long_nv}" = "yes" -a \
|
||||||
[Define to 1 if Solaris libc atomic functions \
|
"${ac_cv_func_atomic_cas_32}" = "yes" -a \
|
||||||
are available])
|
"${ac_cv_func_atomic_cas_64}" = "yes" -a \
|
||||||
)
|
"${ac_cv_func_atomic_cas_ulong}" = "yes" -a \
|
||||||
|
"${ac_cv_func_atomic_swap_uchar}" = "yes" ; then
|
||||||
|
|
||||||
|
AC_DEFINE([HAVE_IB_SOLARIS_ATOMICS], [1],
|
||||||
|
[Define to 1 if Solaris libc atomic functions are available]
|
||||||
|
)
|
||||||
|
fi
|
||||||
|
|
||||||
AC_MSG_CHECKING(whether pthread_t can be used by Solaris libc atomic functions)
|
AC_MSG_CHECKING(whether pthread_t can be used by Solaris libc atomic functions)
|
||||||
# either define HAVE_IB_ATOMIC_PTHREAD_T_SOLARIS or not
|
# either define HAVE_IB_ATOMIC_PTHREAD_T_SOLARIS or not
|
||||||
|
@ -573,7 +573,7 @@ handle_new_error:
|
|||||||
"InnoDB: If the mysqld server crashes"
|
"InnoDB: If the mysqld server crashes"
|
||||||
" after the startup or when\n"
|
" after the startup or when\n"
|
||||||
"InnoDB: you dump the tables, look at\n"
|
"InnoDB: you dump the tables, look at\n"
|
||||||
"InnoDB: " REFMAN "forcing-recovery.html"
|
"InnoDB: " REFMAN "forcing-innodb-recovery.html"
|
||||||
" for help.\n", stderr);
|
" for help.\n", stderr);
|
||||||
break;
|
break;
|
||||||
case DB_FOREIGN_EXCEED_MAX_CASCADE:
|
case DB_FOREIGN_EXCEED_MAX_CASCADE:
|
||||||
|
@ -413,7 +413,7 @@ row_purge_upd_exist_or_extern(
|
|||||||
while (node->index != NULL) {
|
while (node->index != NULL) {
|
||||||
index = node->index;
|
index = node->index;
|
||||||
|
|
||||||
if (row_upd_changes_ord_field_binary(NULL, node->index,
|
if (row_upd_changes_ord_field_binary(NULL, NULL, node->index,
|
||||||
node->update)) {
|
node->update)) {
|
||||||
/* Build the older version of the index entry */
|
/* Build the older version of the index entry */
|
||||||
entry = row_build_index_entry(node->row, NULL,
|
entry = row_build_index_entry(node->row, NULL,
|
||||||
|
@ -668,19 +668,18 @@ row_undo_mod_upd_exist_sec(
|
|||||||
while (node->index != NULL) {
|
while (node->index != NULL) {
|
||||||
index = node->index;
|
index = node->index;
|
||||||
|
|
||||||
if (row_upd_changes_ord_field_binary(node->row, node->index,
|
if (row_upd_changes_ord_field_binary(
|
||||||
node->update)) {
|
node->row, node->ext, node->index, node->update)) {
|
||||||
|
|
||||||
/* Build the newest version of the index entry */
|
/* Build the newest version of the index entry */
|
||||||
entry = row_build_index_entry(node->row, node->ext,
|
entry = row_build_index_entry(node->row, node->ext,
|
||||||
index, heap);
|
index, heap);
|
||||||
if (UNIV_UNLIKELY(!entry)) {
|
if (UNIV_UNLIKELY(!entry)) {
|
||||||
/* The server must have crashed in
|
/* The server must have crashed in
|
||||||
row_upd_clust_rec_by_insert(), in
|
row_upd_clust_rec_by_insert() before
|
||||||
row_ins_index_entry_low() before
|
the updated externally stored columns (BLOBs)
|
||||||
btr_store_big_rec_extern_fields()
|
of the new clustered index entry were
|
||||||
has written the externally stored columns
|
written. */
|
||||||
(BLOBs) of the new clustered index entry. */
|
|
||||||
|
|
||||||
/* The table must be in DYNAMIC or COMPRESSED
|
/* The table must be in DYNAMIC or COMPRESSED
|
||||||
format. REDUNDANT and COMPACT formats
|
format. REDUNDANT and COMPACT formats
|
||||||
|
@ -1198,20 +1198,21 @@ row_upd_changes_ord_field_binary(
|
|||||||
row and the data values in update are not
|
row and the data values in update are not
|
||||||
known when this function is called, e.g., at
|
known when this function is called, e.g., at
|
||||||
compile time */
|
compile time */
|
||||||
|
const row_ext_t*ext, /*!< NULL, or prefixes of the externally
|
||||||
|
stored columns in the old row */
|
||||||
dict_index_t* index, /*!< in: index of the record */
|
dict_index_t* index, /*!< in: index of the record */
|
||||||
const upd_t* update) /*!< in: update vector for the row; NOTE: the
|
const upd_t* update) /*!< in: update vector for the row; NOTE: the
|
||||||
field numbers in this MUST be clustered index
|
field numbers in this MUST be clustered index
|
||||||
positions! */
|
positions! */
|
||||||
{
|
{
|
||||||
ulint n_unique;
|
ulint n_unique;
|
||||||
ulint n_upd_fields;
|
ulint i;
|
||||||
ulint i, j;
|
const dict_index_t* clust_index;
|
||||||
dict_index_t* clust_index;
|
|
||||||
|
|
||||||
ut_ad(update && index);
|
ut_ad(update);
|
||||||
|
ut_ad(index);
|
||||||
|
|
||||||
n_unique = dict_index_get_n_unique(index);
|
n_unique = dict_index_get_n_unique(index);
|
||||||
n_upd_fields = upd_get_n_fields(update);
|
|
||||||
|
|
||||||
clust_index = dict_table_get_first_index(index->table);
|
clust_index = dict_table_get_first_index(index->table);
|
||||||
|
|
||||||
@ -1219,33 +1220,72 @@ row_upd_changes_ord_field_binary(
|
|||||||
|
|
||||||
const dict_field_t* ind_field;
|
const dict_field_t* ind_field;
|
||||||
const dict_col_t* col;
|
const dict_col_t* col;
|
||||||
ulint col_pos;
|
|
||||||
ulint col_no;
|
ulint col_no;
|
||||||
|
const upd_field_t* upd_field;
|
||||||
|
const dfield_t* dfield;
|
||||||
|
dfield_t dfield_ext;
|
||||||
|
ulint dfield_len;
|
||||||
|
const byte* buf;
|
||||||
|
|
||||||
ind_field = dict_index_get_nth_field(index, i);
|
ind_field = dict_index_get_nth_field(index, i);
|
||||||
col = dict_field_get_col(ind_field);
|
col = dict_field_get_col(ind_field);
|
||||||
col_pos = dict_col_get_clust_pos(col, clust_index);
|
|
||||||
col_no = dict_col_get_no(col);
|
col_no = dict_col_get_no(col);
|
||||||
|
|
||||||
for (j = 0; j < n_upd_fields; j++) {
|
upd_field = upd_get_field_by_field_no(
|
||||||
|
update, dict_col_get_clust_pos(col, clust_index));
|
||||||
|
|
||||||
const upd_field_t* upd_field
|
if (upd_field == NULL) {
|
||||||
= upd_get_nth_field(update, j);
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
/* Note that if the index field is a column prefix
|
if (row == NULL) {
|
||||||
then it may be that row does not contain an externally
|
ut_ad(ext == NULL);
|
||||||
stored part of the column value, and we cannot compare
|
return(TRUE);
|
||||||
the datas */
|
}
|
||||||
|
|
||||||
if (col_pos == upd_field->field_no
|
dfield = dtuple_get_nth_field(row, col_no);
|
||||||
&& (row == NULL
|
|
||||||
|| ind_field->prefix_len > 0
|
|
||||||
|| !dfield_datas_are_binary_equal(
|
|
||||||
dtuple_get_nth_field(row, col_no),
|
|
||||||
&(upd_field->new_val)))) {
|
|
||||||
|
|
||||||
return(TRUE);
|
/* This treatment of column prefix indexes is loosely
|
||||||
|
based on row_build_index_entry(). */
|
||||||
|
|
||||||
|
if (UNIV_LIKELY(ind_field->prefix_len == 0)
|
||||||
|
|| dfield_is_null(dfield)) {
|
||||||
|
/* do nothing special */
|
||||||
|
} else if (UNIV_LIKELY_NULL(ext)) {
|
||||||
|
/* See if the column is stored externally. */
|
||||||
|
buf = row_ext_lookup(ext, col_no, &dfield_len);
|
||||||
|
|
||||||
|
ut_ad(col->ord_part);
|
||||||
|
|
||||||
|
if (UNIV_LIKELY_NULL(buf)) {
|
||||||
|
if (UNIV_UNLIKELY(buf == field_ref_zero)) {
|
||||||
|
/* This should never happen, but
|
||||||
|
we try to fail safe here. */
|
||||||
|
ut_ad(0);
|
||||||
|
return(TRUE);
|
||||||
|
}
|
||||||
|
|
||||||
|
goto copy_dfield;
|
||||||
}
|
}
|
||||||
|
} else if (dfield_is_ext(dfield)) {
|
||||||
|
dfield_len = dfield_get_len(dfield);
|
||||||
|
ut_a(dfield_len > BTR_EXTERN_FIELD_REF_SIZE);
|
||||||
|
dfield_len -= BTR_EXTERN_FIELD_REF_SIZE;
|
||||||
|
ut_a(dict_index_is_clust(index)
|
||||||
|
|| ind_field->prefix_len <= dfield_len);
|
||||||
|
buf = dfield_get_data(dfield);
|
||||||
|
copy_dfield:
|
||||||
|
ut_a(dfield_len > 0);
|
||||||
|
dfield_copy(&dfield_ext, dfield);
|
||||||
|
dfield_set_data(&dfield_ext, buf, dfield_len);
|
||||||
|
dfield = &dfield_ext;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!dfield_datas_are_binary_equal(
|
||||||
|
dfield, &upd_field->new_val,
|
||||||
|
ind_field->prefix_len)) {
|
||||||
|
|
||||||
|
return(TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1329,7 +1369,7 @@ row_upd_changes_first_fields_binary(
|
|||||||
if (col_pos == upd_field->field_no
|
if (col_pos == upd_field->field_no
|
||||||
&& !dfield_datas_are_binary_equal(
|
&& !dfield_datas_are_binary_equal(
|
||||||
dtuple_get_nth_field(entry, i),
|
dtuple_get_nth_field(entry, i),
|
||||||
&(upd_field->new_val))) {
|
&upd_field->new_val, 0)) {
|
||||||
|
|
||||||
return(TRUE);
|
return(TRUE);
|
||||||
}
|
}
|
||||||
@ -1568,14 +1608,99 @@ row_upd_sec_step(
|
|||||||
ut_ad(!dict_index_is_clust(node->index));
|
ut_ad(!dict_index_is_clust(node->index));
|
||||||
|
|
||||||
if (node->state == UPD_NODE_UPDATE_ALL_SEC
|
if (node->state == UPD_NODE_UPDATE_ALL_SEC
|
||||||
|| row_upd_changes_ord_field_binary(node->row, node->index,
|
|| row_upd_changes_ord_field_binary(node->row, node->ext,
|
||||||
node->update)) {
|
node->index, node->update)) {
|
||||||
return(row_upd_sec_index_entry(node, thr));
|
return(row_upd_sec_index_entry(node, thr));
|
||||||
}
|
}
|
||||||
|
|
||||||
return(DB_SUCCESS);
|
return(DB_SUCCESS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef UNIV_DEBUG
|
||||||
|
# define row_upd_clust_rec_by_insert_inherit(rec,offsets,entry,update) \
|
||||||
|
row_upd_clust_rec_by_insert_inherit_func(rec,offsets,entry,update)
|
||||||
|
#else /* UNIV_DEBUG */
|
||||||
|
# define row_upd_clust_rec_by_insert_inherit(rec,offsets,entry,update) \
|
||||||
|
row_upd_clust_rec_by_insert_inherit_func(entry,update)
|
||||||
|
#endif /* UNIV_DEBUG */
|
||||||
|
/*******************************************************************//**
|
||||||
|
Mark non-updated off-page columns inherited when the primary key is
|
||||||
|
updated. We must mark them as inherited in entry, so that they are not
|
||||||
|
freed in a rollback. A limited version of this function used to be
|
||||||
|
called btr_cur_mark_dtuple_inherited_extern().
|
||||||
|
@return TRUE if any columns were inherited */
|
||||||
|
static __attribute__((warn_unused_result))
|
||||||
|
ibool
|
||||||
|
row_upd_clust_rec_by_insert_inherit_func(
|
||||||
|
/*=====================================*/
|
||||||
|
#ifdef UNIV_DEBUG
|
||||||
|
const rec_t* rec, /*!< in: old record, or NULL */
|
||||||
|
const ulint* offsets,/*!< in: rec_get_offsets(rec), or NULL */
|
||||||
|
#endif /* UNIV_DEBUG */
|
||||||
|
dtuple_t* entry, /*!< in/out: updated entry to be
|
||||||
|
inserted into the clustered index */
|
||||||
|
const upd_t* update) /*!< in: update vector */
|
||||||
|
{
|
||||||
|
ibool inherit = FALSE;
|
||||||
|
ulint i;
|
||||||
|
|
||||||
|
ut_ad(!rec == !offsets);
|
||||||
|
ut_ad(!rec || rec_offs_any_extern(offsets));
|
||||||
|
|
||||||
|
for (i = 0; i < dtuple_get_n_fields(entry); i++) {
|
||||||
|
dfield_t* dfield = dtuple_get_nth_field(entry, i);
|
||||||
|
byte* data;
|
||||||
|
ulint len;
|
||||||
|
|
||||||
|
ut_ad(!offsets
|
||||||
|
|| !rec_offs_nth_extern(offsets, i)
|
||||||
|
== !dfield_is_ext(dfield)
|
||||||
|
|| upd_get_field_by_field_no(update, i));
|
||||||
|
if (!dfield_is_ext(dfield)
|
||||||
|
|| upd_get_field_by_field_no(update, i)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef UNIV_DEBUG
|
||||||
|
if (UNIV_LIKELY(rec != NULL)) {
|
||||||
|
const byte* rec_data
|
||||||
|
= rec_get_nth_field(rec, offsets, i, &len);
|
||||||
|
ut_ad(len == dfield_get_len(dfield));
|
||||||
|
ut_ad(len != UNIV_SQL_NULL);
|
||||||
|
ut_ad(len >= BTR_EXTERN_FIELD_REF_SIZE);
|
||||||
|
|
||||||
|
rec_data += len - BTR_EXTERN_FIELD_REF_SIZE;
|
||||||
|
|
||||||
|
/* The pointer must not be zero. */
|
||||||
|
ut_ad(memcmp(rec_data, field_ref_zero,
|
||||||
|
BTR_EXTERN_FIELD_REF_SIZE));
|
||||||
|
/* The BLOB must be owned. */
|
||||||
|
ut_ad(!(rec_data[BTR_EXTERN_LEN]
|
||||||
|
& BTR_EXTERN_OWNER_FLAG));
|
||||||
|
}
|
||||||
|
#endif /* UNIV_DEBUG */
|
||||||
|
|
||||||
|
len = dfield_get_len(dfield);
|
||||||
|
ut_a(len != UNIV_SQL_NULL);
|
||||||
|
ut_a(len >= BTR_EXTERN_FIELD_REF_SIZE);
|
||||||
|
data = dfield_get_data(dfield);
|
||||||
|
data += len - BTR_EXTERN_FIELD_REF_SIZE;
|
||||||
|
/* The pointer must not be zero. */
|
||||||
|
ut_a(memcmp(data, field_ref_zero, BTR_EXTERN_FIELD_REF_SIZE));
|
||||||
|
/* The BLOB must be owned. */
|
||||||
|
ut_a(!(data[BTR_EXTERN_LEN] & BTR_EXTERN_OWNER_FLAG));
|
||||||
|
|
||||||
|
data[BTR_EXTERN_LEN] |= BTR_EXTERN_INHERITED_FLAG;
|
||||||
|
/* The BTR_EXTERN_INHERITED_FLAG only matters in
|
||||||
|
rollback. Purge will always free the extern fields of
|
||||||
|
a delete-marked row. */
|
||||||
|
|
||||||
|
inherit = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return(inherit);
|
||||||
|
}
|
||||||
|
|
||||||
/***********************************************************//**
|
/***********************************************************//**
|
||||||
Marks the clustered index record deleted and inserts the updated version
|
Marks the clustered index record deleted and inserts the updated version
|
||||||
of the record to the index. This function should be used when the ordering
|
of the record to the index. This function should be used when the ordering
|
||||||
@ -1594,14 +1719,16 @@ row_upd_clust_rec_by_insert(
|
|||||||
a foreign key constraint */
|
a foreign key constraint */
|
||||||
mtr_t* mtr) /*!< in/out: mtr; gets committed here */
|
mtr_t* mtr) /*!< in/out: mtr; gets committed here */
|
||||||
{
|
{
|
||||||
mem_heap_t* heap = NULL;
|
mem_heap_t* heap;
|
||||||
btr_pcur_t* pcur;
|
btr_pcur_t* pcur;
|
||||||
btr_cur_t* btr_cur;
|
btr_cur_t* btr_cur;
|
||||||
trx_t* trx;
|
trx_t* trx;
|
||||||
dict_table_t* table;
|
dict_table_t* table;
|
||||||
dtuple_t* entry;
|
dtuple_t* entry;
|
||||||
ulint err;
|
ulint err;
|
||||||
ibool change_ownership = FALSE;
|
ibool change_ownership = FALSE;
|
||||||
|
rec_t* rec;
|
||||||
|
ulint* offsets = NULL;
|
||||||
|
|
||||||
ut_ad(node);
|
ut_ad(node);
|
||||||
ut_ad(dict_index_is_clust(index));
|
ut_ad(dict_index_is_clust(index));
|
||||||
@ -1611,53 +1738,7 @@ row_upd_clust_rec_by_insert(
|
|||||||
pcur = node->pcur;
|
pcur = node->pcur;
|
||||||
btr_cur = btr_pcur_get_btr_cur(pcur);
|
btr_cur = btr_pcur_get_btr_cur(pcur);
|
||||||
|
|
||||||
if (node->state != UPD_NODE_INSERT_CLUSTERED) {
|
heap = mem_heap_create(1000);
|
||||||
rec_t* rec;
|
|
||||||
dict_index_t* index;
|
|
||||||
ulint offsets_[REC_OFFS_NORMAL_SIZE];
|
|
||||||
ulint* offsets;
|
|
||||||
rec_offs_init(offsets_);
|
|
||||||
|
|
||||||
err = btr_cur_del_mark_set_clust_rec(BTR_NO_LOCKING_FLAG,
|
|
||||||
btr_cur, TRUE, thr, mtr);
|
|
||||||
if (err != DB_SUCCESS) {
|
|
||||||
mtr_commit(mtr);
|
|
||||||
return(err);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Mark as not-owned the externally stored fields which the new
|
|
||||||
row inherits from the delete marked record: purge should not
|
|
||||||
free those externally stored fields even if the delete marked
|
|
||||||
record is removed from the index tree, or updated. */
|
|
||||||
|
|
||||||
rec = btr_cur_get_rec(btr_cur);
|
|
||||||
index = dict_table_get_first_index(table);
|
|
||||||
offsets = rec_get_offsets(rec, index, offsets_,
|
|
||||||
ULINT_UNDEFINED, &heap);
|
|
||||||
change_ownership = btr_cur_mark_extern_inherited_fields(
|
|
||||||
btr_cur_get_page_zip(btr_cur), rec, index, offsets,
|
|
||||||
node->update, mtr);
|
|
||||||
if (check_ref) {
|
|
||||||
/* NOTE that the following call loses
|
|
||||||
the position of pcur ! */
|
|
||||||
err = row_upd_check_references_constraints(
|
|
||||||
node, pcur, table, index, offsets, thr, mtr);
|
|
||||||
if (err != DB_SUCCESS) {
|
|
||||||
mtr_commit(mtr);
|
|
||||||
if (UNIV_LIKELY_NULL(heap)) {
|
|
||||||
mem_heap_free(heap);
|
|
||||||
}
|
|
||||||
return(err);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
mtr_commit(mtr);
|
|
||||||
|
|
||||||
if (!heap) {
|
|
||||||
heap = mem_heap_create(500);
|
|
||||||
}
|
|
||||||
node->state = UPD_NODE_INSERT_CLUSTERED;
|
|
||||||
|
|
||||||
entry = row_build_index_entry(node->upd_row, node->upd_ext,
|
entry = row_build_index_entry(node->upd_row, node->upd_ext,
|
||||||
index, heap);
|
index, heap);
|
||||||
@ -1665,23 +1746,104 @@ row_upd_clust_rec_by_insert(
|
|||||||
|
|
||||||
row_upd_index_entry_sys_field(entry, index, DATA_TRX_ID, trx->id);
|
row_upd_index_entry_sys_field(entry, index, DATA_TRX_ID, trx->id);
|
||||||
|
|
||||||
if (change_ownership) {
|
switch (node->state) {
|
||||||
/* If we return from a lock wait, for example, we may have
|
default:
|
||||||
extern fields marked as not-owned in entry (marked in the
|
ut_error;
|
||||||
if-branch above). We must unmark them, take the ownership
|
case UPD_NODE_INSERT_BLOB:
|
||||||
back. */
|
/* A lock wait occurred in row_ins_index_entry() in
|
||||||
|
the previous invocation of this function. Mark the
|
||||||
|
off-page columns in the entry inherited. */
|
||||||
|
|
||||||
btr_cur_unmark_dtuple_extern_fields(entry);
|
change_ownership = row_upd_clust_rec_by_insert_inherit(
|
||||||
|
NULL, NULL, entry, node->update);
|
||||||
|
ut_a(change_ownership);
|
||||||
|
/* fall through */
|
||||||
|
case UPD_NODE_INSERT_CLUSTERED:
|
||||||
|
/* A lock wait occurred in row_ins_index_entry() in
|
||||||
|
the previous invocation of this function. */
|
||||||
|
break;
|
||||||
|
case UPD_NODE_UPDATE_CLUSTERED:
|
||||||
|
/* This is the first invocation of the function where
|
||||||
|
we update the primary key. Delete-mark the old record
|
||||||
|
in the clustered index and prepare to insert a new entry. */
|
||||||
|
rec = btr_cur_get_rec(btr_cur);
|
||||||
|
offsets = rec_get_offsets(rec, index, NULL,
|
||||||
|
ULINT_UNDEFINED, &heap);
|
||||||
|
ut_ad(page_rec_is_user_rec(rec));
|
||||||
|
|
||||||
/* We must mark non-updated extern fields in entry as
|
err = btr_cur_del_mark_set_clust_rec(
|
||||||
inherited, so that a possible rollback will not free them. */
|
BTR_NO_LOCKING_FLAG, btr_cur_get_block(btr_cur),
|
||||||
|
rec, index, offsets, TRUE, thr, mtr);
|
||||||
|
if (err != DB_SUCCESS) {
|
||||||
|
err_exit:
|
||||||
|
mtr_commit(mtr);
|
||||||
|
mem_heap_free(heap);
|
||||||
|
return(err);
|
||||||
|
}
|
||||||
|
|
||||||
btr_cur_mark_dtuple_inherited_extern(entry, node->update);
|
/* If the the new row inherits externally stored
|
||||||
|
fields (off-page columns a.k.a. BLOBs) from the
|
||||||
|
delete-marked old record, mark them disowned by the
|
||||||
|
old record and owned by the new entry. */
|
||||||
|
|
||||||
|
if (rec_offs_any_extern(offsets)) {
|
||||||
|
change_ownership = row_upd_clust_rec_by_insert_inherit(
|
||||||
|
rec, offsets, entry, node->update);
|
||||||
|
|
||||||
|
if (change_ownership) {
|
||||||
|
btr_pcur_store_position(pcur, mtr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (check_ref) {
|
||||||
|
/* NOTE that the following call loses
|
||||||
|
the position of pcur ! */
|
||||||
|
err = row_upd_check_references_constraints(
|
||||||
|
node, pcur, table, index, offsets, thr, mtr);
|
||||||
|
if (err != DB_SUCCESS) {
|
||||||
|
goto err_exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mtr_commit(mtr);
|
||||||
|
|
||||||
err = row_ins_index_entry(index, entry,
|
err = row_ins_index_entry(index, entry,
|
||||||
node->upd_ext ? node->upd_ext->n_ext : 0,
|
node->upd_ext ? node->upd_ext->n_ext : 0,
|
||||||
TRUE, thr);
|
TRUE, thr);
|
||||||
|
node->state = change_ownership
|
||||||
|
? UPD_NODE_INSERT_BLOB
|
||||||
|
: UPD_NODE_INSERT_CLUSTERED;
|
||||||
|
|
||||||
|
if (err == DB_SUCCESS && change_ownership) {
|
||||||
|
/* Mark the non-updated fields disowned by the old record. */
|
||||||
|
|
||||||
|
/* NOTE: this transaction has an x-lock on the record
|
||||||
|
and therefore other transactions cannot modify the
|
||||||
|
record when we have no latch on the page. In addition,
|
||||||
|
we assume that other query threads of the same
|
||||||
|
transaction do not modify the record in the meantime.
|
||||||
|
Therefore we can assert that the restoration of the
|
||||||
|
cursor succeeds. */
|
||||||
|
|
||||||
|
mtr_start(mtr);
|
||||||
|
|
||||||
|
if (!btr_pcur_restore_position(BTR_MODIFY_LEAF, pcur, mtr)) {
|
||||||
|
ut_error;
|
||||||
|
}
|
||||||
|
|
||||||
|
rec = btr_cur_get_rec(btr_cur);
|
||||||
|
offsets = rec_get_offsets(rec, index, offsets,
|
||||||
|
ULINT_UNDEFINED, &heap);
|
||||||
|
ut_ad(page_rec_is_user_rec(rec));
|
||||||
|
|
||||||
|
btr_cur_disown_inherited_fields(
|
||||||
|
btr_cur_get_page_zip(btr_cur),
|
||||||
|
rec, index, offsets, node->update, mtr);
|
||||||
|
|
||||||
|
mtr_commit(mtr);
|
||||||
|
}
|
||||||
|
|
||||||
mem_heap_free(heap);
|
mem_heap_free(heap);
|
||||||
|
|
||||||
return(err);
|
return(err);
|
||||||
@ -1825,8 +1987,9 @@ row_upd_del_mark_clust_rec(
|
|||||||
/* Mark the clustered index record deleted; we do not have to check
|
/* Mark the clustered index record deleted; we do not have to check
|
||||||
locks, because we assume that we have an x-lock on the record */
|
locks, because we assume that we have an x-lock on the record */
|
||||||
|
|
||||||
err = btr_cur_del_mark_set_clust_rec(BTR_NO_LOCKING_FLAG,
|
err = btr_cur_del_mark_set_clust_rec(
|
||||||
btr_cur, TRUE, thr, mtr);
|
BTR_NO_LOCKING_FLAG, btr_cur_get_block(btr_cur),
|
||||||
|
btr_cur_get_rec(btr_cur), index, offsets, TRUE, thr, mtr);
|
||||||
if (err == DB_SUCCESS && check_ref) {
|
if (err == DB_SUCCESS && check_ref) {
|
||||||
/* NOTE that the following call loses the position of pcur ! */
|
/* NOTE that the following call loses the position of pcur ! */
|
||||||
|
|
||||||
@ -1973,7 +2136,8 @@ exit_func:
|
|||||||
|
|
||||||
row_upd_store_row(node);
|
row_upd_store_row(node);
|
||||||
|
|
||||||
if (row_upd_changes_ord_field_binary(node->row, index, node->update)) {
|
if (row_upd_changes_ord_field_binary(node->row, node->ext, index,
|
||||||
|
node->update)) {
|
||||||
|
|
||||||
/* Update causes an ordering field (ordering fields within
|
/* Update causes an ordering field (ordering fields within
|
||||||
the B-tree) of the clustered index record to change: perform
|
the B-tree) of the clustered index record to change: perform
|
||||||
@ -2042,7 +2206,8 @@ row_upd(
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (node->state == UPD_NODE_UPDATE_CLUSTERED
|
if (node->state == UPD_NODE_UPDATE_CLUSTERED
|
||||||
|| node->state == UPD_NODE_INSERT_CLUSTERED) {
|
|| node->state == UPD_NODE_INSERT_CLUSTERED
|
||||||
|
|| node->state == UPD_NODE_INSERT_BLOB) {
|
||||||
|
|
||||||
log_free_check();
|
log_free_check();
|
||||||
err = row_upd_clust_step(node, thr);
|
err = row_upd_clust_step(node, thr);
|
||||||
|
@ -435,7 +435,7 @@ i_s_locks_row_validate(
|
|||||||
/* record lock */
|
/* record lock */
|
||||||
ut_ad(!strcmp("RECORD", row->lock_type));
|
ut_ad(!strcmp("RECORD", row->lock_type));
|
||||||
ut_ad(row->lock_index != NULL);
|
ut_ad(row->lock_index != NULL);
|
||||||
ut_ad(row->lock_data != NULL);
|
/* row->lock_data == NULL if buf_page_try_get() == NULL */
|
||||||
ut_ad(row->lock_page != ULINT_UNDEFINED);
|
ut_ad(row->lock_page != ULINT_UNDEFINED);
|
||||||
ut_ad(row->lock_rec != ULINT_UNDEFINED);
|
ut_ad(row->lock_rec != ULINT_UNDEFINED);
|
||||||
}
|
}
|
||||||
@ -498,7 +498,6 @@ fill_trx_row(
|
|||||||
stmt = innobase_get_stmt(trx->mysql_thd, &stmt_len);
|
stmt = innobase_get_stmt(trx->mysql_thd, &stmt_len);
|
||||||
|
|
||||||
if (stmt != NULL) {
|
if (stmt != NULL) {
|
||||||
|
|
||||||
char query[TRX_I_S_TRX_QUERY_MAX_LEN + 1];
|
char query[TRX_I_S_TRX_QUERY_MAX_LEN + 1];
|
||||||
|
|
||||||
if (stmt_len > TRX_I_S_TRX_QUERY_MAX_LEN) {
|
if (stmt_len > TRX_I_S_TRX_QUERY_MAX_LEN) {
|
||||||
@ -512,6 +511,8 @@ fill_trx_row(
|
|||||||
cache->storage, stmt, stmt_len + 1,
|
cache->storage, stmt, stmt_len + 1,
|
||||||
MAX_ALLOWED_FOR_STORAGE(cache));
|
MAX_ALLOWED_FOR_STORAGE(cache));
|
||||||
|
|
||||||
|
row->trx_query_cs = innobase_get_charset(trx->mysql_thd);
|
||||||
|
|
||||||
if (row->trx_query == NULL) {
|
if (row->trx_query == NULL) {
|
||||||
|
|
||||||
return(FALSE);
|
return(FALSE);
|
||||||
|
@ -79,7 +79,7 @@ ut_dbg_assertion_failed(
|
|||||||
" or crashes, even\n"
|
" or crashes, even\n"
|
||||||
"InnoDB: immediately after the mysqld startup, there may be\n"
|
"InnoDB: immediately after the mysqld startup, there may be\n"
|
||||||
"InnoDB: corruption in the InnoDB tablespace. Please refer to\n"
|
"InnoDB: corruption in the InnoDB tablespace. Please refer to\n"
|
||||||
"InnoDB: " REFMAN "forcing-recovery.html\n"
|
"InnoDB: " REFMAN "forcing-innodb-recovery.html\n"
|
||||||
"InnoDB: about forcing recovery.\n", stderr);
|
"InnoDB: about forcing recovery.\n", stderr);
|
||||||
#if defined(UNIV_SYNC_DEBUG) || !defined(UT_DBG_USE_ABORT)
|
#if defined(UNIV_SYNC_DEBUG) || !defined(UT_DBG_USE_ABORT)
|
||||||
ut_dbg_stop_threads = TRUE;
|
ut_dbg_stop_threads = TRUE;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user