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
d1655ba6
Commit
d1655ba6
authored
Mar 19, 2014
by
Michael Widenius
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge
parents
7ba9f064
913d1f19
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
85 additions
and
2 deletions
+85
-2
mysql-test/r/create_or_replace2.result
mysql-test/r/create_or_replace2.result
+25
-0
mysql-test/t/create_or_replace.test
mysql-test/t/create_or_replace.test
+1
-1
mysql-test/t/create_or_replace2.test
mysql-test/t/create_or_replace2.test
+35
-0
sql/sql_base.cc
sql/sql_base.cc
+6
-0
sql/sql_table.cc
sql/sql_table.cc
+18
-1
No files found.
mysql-test/r/create_or_replace2.result
0 → 100644
View file @
d1655ba6
include/master-slave.inc
[connection master]
drop table if exists t1;
SET @old_debug= @@session.debug;
CREATE TABLE t1 (i INT, KEY(i)) ENGINE=InnoDB;
CREATE OR REPLACE TEMPORARY TABLE tmp (a int, b int, key(a)) engine=myisam;
set debug_dbug='+d,send_kill_after_delete';
CREATE OR REPLACE TABLE t1 LIKE tmp;
set debug_dbug=@old_debug;
SHOW TABLES;
Tables_in_test
t1
show create table t1;
Table Create Table
t1 CREATE TABLE `t1` (
`a` int(11) DEFAULT NULL,
`b` int(11) DEFAULT NULL,
KEY `a` (`a`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1
SHOW TABLES;
Tables_in_test
t1
drop temporary table if exists tmp;
drop table t1;
include/rpl_end.inc
mysql-test/t/create_or_replace.test
View file @
d1655ba6
#
# Check CREATE OR REPLACE
ALTER
TABLE
# Check CREATE OR REPLACE TABLE
#
--
source
include
/
have_innodb
.
inc
...
...
mysql-test/t/create_or_replace2.test
0 → 100644
View file @
d1655ba6
#
# Check CREATE OR REPLACE TABLE for test that requires DEBUG
#
--
source
include
/
have_debug
.
inc
--
source
include
/
master
-
slave
.
inc
--
source
include
/
have_binlog_format_row
.
inc
--
source
include
/
have_xtradb
.
inc
--
disable_warnings
drop
table
if
exists
t1
;
--
enable_warnings
SET
@
old_debug
=
@@
session
.
debug
;
#
# MDEV-5854
# Interrupted CREATE OR REPLACE is written into binlog, and in a wrong format
#
CREATE
TABLE
t1
(
i
INT
,
KEY
(
i
))
ENGINE
=
InnoDB
;
CREATE
OR
REPLACE
TEMPORARY
TABLE
tmp
(
a
int
,
b
int
,
key
(
a
))
engine
=
myisam
;
set
debug_dbug
=
'+d,send_kill_after_delete'
;
CREATE
OR
REPLACE
TABLE
t1
LIKE
tmp
;
set
debug_dbug
=@
old_debug
;
SHOW
TABLES
;
show
create
table
t1
;
--
sync_slave_with_master
SHOW
TABLES
;
--
connection
master
--
disable_warnings
drop
temporary
table
if
exists
tmp
;
--
enable_warnings
drop
table
t1
;
--
source
include
/
rpl_end
.
inc
sql/sql_base.cc
View file @
d1655ba6
...
...
@@ -656,6 +656,12 @@ static void mark_temp_tables_as_free_for_reuse(THD *thd)
{
DBUG_ENTER
(
"mark_temp_tables_as_free_for_reuse"
);
if
(
thd
->
query_id
==
0
)
{
/* Thread has not executed any statement and has not used any tmp tables */
DBUG_VOID_RETURN
;
}
thd
->
lock_temporary_tables
();
for
(
TABLE
*
table
=
thd
->
temporary_tables
;
table
;
table
=
table
->
next
)
{
...
...
sql/sql_table.cc
View file @
d1655ba6
...
...
@@ -2560,6 +2560,18 @@ int mysql_rm_table_no_locks(THD *thd, TABLE_LIST *tables, bool if_exists,
error
=
1
;
}
/*
We are always logging drop of temporary tables.
The reason is to handle the following case:
- Use statement based replication
- CREATE TEMPORARY TABLE foo (logged)
- set row based replication
- DROP TEMPORAY TABLE foo (needs to be logged)
This should be fixed so that we remember if creation of the
temporary table was logged and only log it if the creation was
logged.
*/
if
(
non_trans_tmp_table_deleted
||
trans_tmp_table_deleted
||
non_tmp_table_deleted
)
{
...
...
@@ -4628,6 +4640,7 @@ int create_table_impl(THD *thd,
thd
->
variables
.
option_bits
|=
OPTION_KEEP_LOG
;
thd
->
log_current_statement
=
1
;
create_info
->
table_was_deleted
=
1
;
DBUG_EXECUTE_IF
(
"send_kill_after_delete"
,
thd
->
killed
=
KILL_QUERY
;
);
/*
The test of query_tables is to ensure we have any tables in the
...
...
@@ -4769,6 +4782,7 @@ int create_table_impl(THD *thd,
err:
THD_STAGE_INFO
(
thd
,
stage_after_create
);
delete
file
;
DBUG_PRINT
(
"exit"
,
(
"return: %d"
,
error
));
DBUG_RETURN
(
error
);
warn:
...
...
@@ -5262,7 +5276,8 @@ bool mysql_create_like_table(THD* thd, TABLE_LIST* table,
char
buf
[
2048
];
String
query
(
buf
,
sizeof
(
buf
),
system_charset_info
);
query
.
length
(
0
);
// Have to zero it since constructor doesn't
Open_table_context
ot_ctx
(
thd
,
MYSQL_OPEN_REOPEN
);
Open_table_context
ot_ctx
(
thd
,
MYSQL_OPEN_REOPEN
|
MYSQL_OPEN_IGNORE_KILLED
);
bool
new_table
=
FALSE
;
// Whether newly created table is open.
if
(
create_res
!=
0
)
...
...
@@ -5271,6 +5286,7 @@ bool mysql_create_like_table(THD* thd, TABLE_LIST* table,
Table or view with same name already existed and we where using
IF EXISTS. Continue without logging anything.
*/
do_logging
=
0
;
goto
err
;
}
if
(
!
table
->
table
)
...
...
@@ -5316,6 +5332,7 @@ bool mysql_create_like_table(THD* thd, TABLE_LIST* table,
if
(
write_bin_log
(
thd
,
TRUE
,
query
.
ptr
(),
query
.
length
()))
{
res
=
1
;
do_logging
=
0
;
goto
err
;
}
...
...
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