Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
35184902
Commit
35184902
authored
Nov 28, 2018
by
Marko Mäkelä
Browse files
Options
Browse Files
Download
Plain Diff
Merge 10.2 into 10.3
parents
babb000a
b26e603a
Changes
7
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
123 additions
and
14 deletions
+123
-14
mysql-test/suite/innodb/r/truncate.result
mysql-test/suite/innodb/r/truncate.result
+15
-0
mysql-test/suite/innodb/t/truncate.test
mysql-test/suite/innodb/t/truncate.test
+17
-0
storage/innobase/handler/ha_innodb.cc
storage/innobase/handler/ha_innodb.cc
+14
-13
storage/innobase/handler/ha_innodb.h
storage/innobase/handler/ha_innodb.h
+6
-1
storage/rocksdb/mysql-test/rocksdb/r/xa.result
storage/rocksdb/mysql-test/rocksdb/r/xa.result
+32
-0
storage/rocksdb/mysql-test/rocksdb/t/xa-master.opt
storage/rocksdb/mysql-test/rocksdb/t/xa-master.opt
+1
-0
storage/rocksdb/mysql-test/rocksdb/t/xa.test
storage/rocksdb/mysql-test/rocksdb/t/xa.test
+38
-0
No files found.
mysql-test/suite/innodb/r/truncate.result
View file @
35184902
...
@@ -27,3 +27,18 @@ SHOW TABLE STATUS;
...
@@ -27,3 +27,18 @@ SHOW TABLE STATUS;
Name Engine Version Row_format Rows Avg_row_length Data_length Max_data_length Index_length Data_free Auto_increment Create_time Update_time Check_time Collation Checksum Create_options Comment Max_index_length Temporary
Name Engine Version Row_format Rows Avg_row_length Data_length Max_data_length Index_length Data_free Auto_increment Create_time Update_time Check_time Collation Checksum Create_options Comment Max_index_length Temporary
t1 InnoDB # Compressed # # # # # # 1 # # NULL latin1_swedish_ci NULL key_block_size=4 0 N
t1 InnoDB # Compressed # # # # # # 1 # # NULL latin1_swedish_ci NULL key_block_size=4 0 N
DROP TABLE t1;
DROP TABLE t1;
#
# MDEV-17859 Operating system errors in file operations
# after failed CREATE
#
CREATE TABLE t1 (a INT) ENGINE=InnoDB;
INSERT INTO t1 VALUES (1);
call mtr.add_suppression("InnoDB: (Operating system )?[Ee]rror number");
call mtr.add_suppression("InnoDB: Cannot create file '.*t1\\.ibd");
FLUSH TABLES;
CREATE TABLE t1 (a INT) ENGINE=InnoDB;
ERROR HY000: Tablespace for table '`test`.`t1`' exists. Please DISCARD the tablespace before IMPORT
SELECT * FROM t1;
a
1
DROP TABLE t1;
mysql-test/suite/innodb/t/truncate.test
View file @
35184902
...
@@ -36,3 +36,20 @@ TRUNCATE TABLE t1;
...
@@ -36,3 +36,20 @@ TRUNCATE TABLE t1;
--
replace_column
3
# 5 # 6 # 7 # 8 # 9 # 10 # 12 # 13 #
--
replace_column
3
# 5 # 6 # 7 # 8 # 9 # 10 # 12 # 13 #
SHOW
TABLE
STATUS
;
SHOW
TABLE
STATUS
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
--
echo
#
--
echo
# MDEV-17859 Operating system errors in file operations
--
echo
# after failed CREATE
--
echo
#
let
$MYSQLD_DATADIR
=
`select @@datadir`
;
CREATE
TABLE
t1
(
a
INT
)
ENGINE
=
InnoDB
;
INSERT
INTO
t1
VALUES
(
1
);
call
mtr
.
add_suppression
(
"InnoDB: (Operating system )?[Ee]rror number"
);
call
mtr
.
add_suppression
(
"InnoDB: Cannot create file '.*t1
\\
.ibd"
);
FLUSH
TABLES
;
--
move_file
$MYSQLD_DATADIR
/
test
/
t1
.
frm
$MYSQLD_DATADIR
/
test
/
hidden
.
frm
--
error
ER_TABLESPACE_EXISTS
CREATE
TABLE
t1
(
a
INT
)
ENGINE
=
InnoDB
;
--
move_file
$MYSQLD_DATADIR
/
test
/
hidden
.
frm
$MYSQLD_DATADIR
/
test
/
t1
.
frm
SELECT
*
FROM
t1
;
DROP
TABLE
t1
;
storage/innobase/handler/ha_innodb.cc
View file @
35184902
...
@@ -10794,6 +10794,7 @@ create_table_info_t::create_table_def()
...
@@ -10794,6 +10794,7 @@ create_table_info_t::create_table_def()
DBUG_PRINT
(
"enter"
,
(
"table_name: %s"
,
m_table_name
));
DBUG_PRINT
(
"enter"
,
(
"table_name: %s"
,
m_table_name
));
DBUG_ASSERT
(
m_trx
->
mysql_thd
==
m_thd
);
DBUG_ASSERT
(
m_trx
->
mysql_thd
==
m_thd
);
DBUG_ASSERT
(
!
m_drop_before_rollback
);
/* MySQL does the name length check. But we do additional check
/* MySQL does the name length check. But we do additional check
on the name length here */
on the name length here */
...
@@ -11056,6 +11057,7 @@ create_table_info_t::create_table_def()
...
@@ -11056,6 +11057,7 @@ create_table_info_t::create_table_def()
table
,
m_trx
,
table
,
m_trx
,
(
fil_encryption_t
)
options
->
encryption
,
(
fil_encryption_t
)
options
->
encryption
,
(
uint32_t
)
options
->
encryption_key_id
);
(
uint32_t
)
options
->
encryption_key_id
);
m_drop_before_rollback
=
(
err
==
DB_SUCCESS
);
}
}
DBUG_EXECUTE_IF
(
"ib_crash_during_create_for_encryption"
,
DBUG_EXECUTE_IF
(
"ib_crash_during_create_for_encryption"
,
...
@@ -12282,6 +12284,9 @@ int create_table_info_t::create_table(bool create_fk)
...
@@ -12282,6 +12284,9 @@ int create_table_info_t::create_table(bool create_fk)
DBUG_RETURN
(
error
);
DBUG_RETURN
(
error
);
}
}
DBUG_ASSERT
(
m_drop_before_rollback
==
!
(
m_flags2
&
DICT_TF2_TEMPORARY
));
/* Create the keys */
/* Create the keys */
if
(
m_form
->
s
->
keys
==
0
||
primary_key_no
==
-
1
)
{
if
(
m_form
->
s
->
keys
==
0
||
primary_key_no
==
-
1
)
{
...
@@ -12340,6 +12345,7 @@ int create_table_info_t::create_table(bool create_fk)
...
@@ -12340,6 +12345,7 @@ int create_table_info_t::create_table(bool create_fk)
my_error
(
ER_WRONG_NAME_FOR_INDEX
,
MYF
(
0
),
my_error
(
ER_WRONG_NAME_FOR_INDEX
,
MYF
(
0
),
FTS_DOC_ID_INDEX_NAME
);
FTS_DOC_ID_INDEX_NAME
);
m_drop_before_rollback
=
false
;
error
=
-
1
;
error
=
-
1
;
DBUG_RETURN
(
error
);
DBUG_RETURN
(
error
);
case
FTS_EXIST_DOC_ID_INDEX
:
case
FTS_EXIST_DOC_ID_INDEX
:
...
@@ -12354,16 +12360,6 @@ int create_table_info_t::create_table(bool create_fk)
...
@@ -12354,16 +12360,6 @@ int create_table_info_t::create_table(bool create_fk)
error
=
convert_error_code_to_mysql
(
err
,
0
,
NULL
);
error
=
convert_error_code_to_mysql
(
err
,
0
,
NULL
);
if
(
error
)
{
if
(
error
)
{
/* Drop the being-created table before rollback,
so that rollback can possibly rename back a table
that could have been renamed before
the failed creation. */
m_trx
->
error_state
=
DB_SUCCESS
;
row_drop_table_for_mysql
(
m_table_name
,
m_trx
,
SQLCOM_TRUNCATE
);
trx_rollback_to_savepoint
(
m_trx
,
NULL
);
m_trx
->
error_state
=
DB_SUCCESS
;
DBUG_RETURN
(
error
);
DBUG_RETURN
(
error
);
}
}
}
}
...
@@ -12429,6 +12425,9 @@ int create_table_info_t::create_table(bool create_fk)
...
@@ -12429,6 +12425,9 @@ int create_table_info_t::create_table(bool create_fk)
error
=
convert_error_code_to_mysql
(
err
,
m_flags
,
NULL
);
error
=
convert_error_code_to_mysql
(
err
,
m_flags
,
NULL
);
if
(
error
)
{
if
(
error
)
{
/* row_table_add_foreign_constraints() dropped
the table */
m_drop_before_rollback
=
false
;
DBUG_RETURN
(
error
);
DBUG_RETURN
(
error
);
}
}
}
}
...
@@ -12590,9 +12589,11 @@ ha_innobase::create(
...
@@ -12590,9 +12589,11 @@ ha_innobase::create(
/* Drop the being-created table before rollback,
/* Drop the being-created table before rollback,
so that rollback can possibly rename back a table
so that rollback can possibly rename back a table
that could have been renamed before the failed creation. */
that could have been renamed before the failed creation. */
if
(
info
.
drop_before_rollback
())
{
trx
->
error_state
=
DB_SUCCESS
;
trx
->
error_state
=
DB_SUCCESS
;
row_drop_table_for_mysql
(
info
.
table_name
(),
trx
,
row_drop_table_for_mysql
(
info
.
table_name
(),
SQLCOM_TRUNCATE
,
true
);
trx
,
SQLCOM_TRUNCATE
,
true
);
}
trx_rollback_for_mysql
(
trx
);
trx_rollback_for_mysql
(
trx
);
row_mysql_unlock_data_dictionary
(
trx
);
row_mysql_unlock_data_dictionary
(
trx
);
if
(
own_trx
)
{
if
(
own_trx
)
{
...
...
storage/innobase/handler/ha_innodb.h
View file @
35184902
...
@@ -656,7 +656,7 @@ class create_table_info_t
...
@@ -656,7 +656,7 @@ class create_table_info_t
m_trx
(
trx
),
m_trx
(
trx
),
m_form
(
form
),
m_form
(
form
),
m_create_info
(
create_info
),
m_create_info
(
create_info
),
m_table_name
(
table_name
),
m_table
(
NULL
),
m_table_name
(
table_name
),
m_table
(
NULL
),
m_drop_before_rollback
(
false
),
m_remote_path
(
remote_path
),
m_remote_path
(
remote_path
),
m_innodb_file_per_table
(
file_per_table
)
m_innodb_file_per_table
(
file_per_table
)
{}
{}
...
@@ -729,6 +729,9 @@ class create_table_info_t
...
@@ -729,6 +729,9 @@ class create_table_info_t
const
char
*
table_name
()
const
const
char
*
table_name
()
const
{
return
(
m_table_name
);
}
{
return
(
m_table_name
);
}
/** @return whether the table needs to be dropped on rollback */
bool
drop_before_rollback
()
const
{
return
m_drop_before_rollback
;
}
THD
*
thd
()
const
THD
*
thd
()
const
{
return
(
m_thd
);
}
{
return
(
m_thd
);
}
...
@@ -772,6 +775,8 @@ class create_table_info_t
...
@@ -772,6 +775,8 @@ class create_table_info_t
char
*
m_table_name
;
char
*
m_table_name
;
/** Table */
/** Table */
dict_table_t
*
m_table
;
dict_table_t
*
m_table
;
/** Whether the table needs to be dropped before rollback */
bool
m_drop_before_rollback
;
/** Remote path (DATA DIRECTORY) or zero length-string */
/** Remote path (DATA DIRECTORY) or zero length-string */
char
*
m_remote_path
;
char
*
m_remote_path
;
...
...
storage/rocksdb/mysql-test/rocksdb/r/xa.result
0 → 100644
View file @
35184902
#
# MDEV-13155: XA recovery not supported for RocksDB (Just a testcase)
#
call mtr.add_suppression("Found .* prepared XA transactions");
connect con1,localhost,root,,test;
DROP TABLE IF EXISTS t1;
CREATE TABLE t1 (a INT) ENGINE=RocksDB;
XA START 'xa1';
INSERT INTO t1 (a) VALUES (1),(2);
XA END 'xa1';
XA PREPARE 'xa1';
connect con2,localhost,root,,test;
XA START 'xa2';
INSERT INTO t1 (a) VALUES (3);
INSERT INTO t1 (a) VALUES (4);
XA END 'xa2';
XA PREPARE 'xa2';
connection default;
SELECT * FROM t1;
a
connect con3,localhost,root,,test;
XA RECOVER;
formatID gtrid_length bqual_length data
1 3 0 xa1
1 3 0 xa2
XA ROLLBACK 'xa1';
XA COMMIT 'xa2';
SELECT a FROM t1;
a
3
4
DROP TABLE t1;
storage/rocksdb/mysql-test/rocksdb/t/xa-master.opt
0 → 100644
View file @
35184902
--rocksdb_flush_log_at_trx_commit=1
storage/rocksdb/mysql-test/rocksdb/t/xa.test
0 → 100644
View file @
35184902
--
echo
#
--
echo
# MDEV-13155: XA recovery not supported for RocksDB (Just a testcase)
--
echo
#
call
mtr
.
add_suppression
(
"Found .* prepared XA transactions"
);
--
connect
(
con1
,
localhost
,
root
,,
test
)
--
disable_warnings
DROP
TABLE
IF
EXISTS
t1
;
--
enable_warnings
CREATE
TABLE
t1
(
a
INT
)
ENGINE
=
RocksDB
;
XA
START
'xa1'
;
INSERT
INTO
t1
(
a
)
VALUES
(
1
),(
2
);
XA
END
'xa1'
;
XA
PREPARE
'xa1'
;
--
connect
(
con2
,
localhost
,
root
,,
test
)
XA
START
'xa2'
;
INSERT
INTO
t1
(
a
)
VALUES
(
3
);
INSERT
INTO
t1
(
a
)
VALUES
(
4
);
XA
END
'xa2'
;
XA
PREPARE
'xa2'
;
--
connection
default
SELECT
*
FROM
t1
;
--
let
$shutdown_timeout
=
0
--
source
include
/
restart_mysqld
.
inc
--
connect
(
con3
,
localhost
,
root
,,
test
)
--
disable_abort_on_error
XA
RECOVER
;
XA
ROLLBACK
'xa1'
;
XA
COMMIT
'xa2'
;
SELECT
a
FROM
t1
;
DROP
TABLE
t1
;
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment