Commit 2a046c6c authored by unknown's avatar unknown

Fix for BUG#7358: removing warning reporting of mysqldump 4.1.8 when calling...

Fix for BUG#7358: removing warning reporting of mysqldump 4.1.8 when calling SHOW CREATE DATABASE, as we deal almost gracefully with it
(back to behaviour of 4.1.7). Warning was not fatal: mysqldump continued. And the good thing is that it helped spot that starting from 4.1.7,
SHOW CREATE DATABASE failed (if --single-transaction and first db has non-empty InnoDB table and there is a second db) and thus mysqldump
produced CREATE DATABASE statements missing the CHARACTER SET clause. Removing the bug which was in the server, and the warning reporting in
mysqldump (compatibility with old servers).


client/mysqldump.c:
  don't report errors as we deal almost gracefully with them (back to code of 4.1.7)
mysql-test/r/flush_block_commit.result:
  result update
mysql-test/t/flush_block_commit.test:
  let's verify that SHOW CREATE DATABASE succeeds even if connection has open transaction.
sql/sql_parse.cc:
  There is no reason to forbid SHOW CREATE DATABASE if connection has an open transaction
parent ac9b0d01
...@@ -1914,7 +1914,7 @@ static int init_dumping(char *database) ...@@ -1914,7 +1914,7 @@ static int init_dumping(char *database)
sprintf(qbuf,"SHOW CREATE DATABASE IF NOT EXISTS %s", sprintf(qbuf,"SHOW CREATE DATABASE IF NOT EXISTS %s",
qdatabase); qdatabase);
if (mysql_query_with_error_report(sock, &dbinfo, qbuf)) if (mysql_query(sock, qbuf) || !(dbinfo = mysql_store_result(sock)))
{ {
/* Old server version, dump generic CREATE DATABASE */ /* Old server version, dump generic CREATE DATABASE */
fprintf(md_result_file, fprintf(md_result_file,
......
...@@ -28,4 +28,12 @@ commit; ...@@ -28,4 +28,12 @@ commit;
unlock tables; unlock tables;
flush tables with read lock; flush tables with read lock;
unlock tables; unlock tables;
begin;
select * from t1;
a
1
10
show create database test;
Database Create Database
test CREATE DATABASE `test` /*!40100 DEFAULT CHARACTER SET latin1 */
drop table t1; drop table t1;
# Let's see if FLUSH TABLES WITH READ LOCK blocks COMMIT of existing # Let's see if FLUSH TABLES WITH READ LOCK blocks COMMIT of existing
# transactions. # transactions.
# We verify that we did not introduce a deadlock. # We verify that we did not introduce a deadlock.
# This is intended to mimick how mysqldump and innobackup work.
-- source include/have_innodb.inc -- source include/have_innodb.inc
...@@ -63,4 +64,11 @@ unlock tables; ...@@ -63,4 +64,11 @@ unlock tables;
connection con2; connection con2;
flush tables with read lock; # bug caused hang here flush tables with read lock; # bug caused hang here
unlock tables; unlock tables;
# BUG#7358 SHOW CREATE DATABASE fails if open transaction
begin;
select * from t1;
show create database test;
drop table t1; drop table t1;
...@@ -3249,11 +3249,6 @@ purposes internal to the MySQL server", MYF(0)); ...@@ -3249,11 +3249,6 @@ purposes internal to the MySQL server", MYF(0));
} }
if (check_access(thd,SELECT_ACL,lex->name,0,1,0)) if (check_access(thd,SELECT_ACL,lex->name,0,1,0))
break; break;
if (thd->locked_tables || thd->active_transaction())
{
send_error(thd,ER_LOCK_OR_ACTIVE_TRANSACTION);
goto error;
}
res=mysqld_show_create_db(thd,lex->name,&lex->create_info); res=mysqld_show_create_db(thd,lex->name,&lex->create_info);
break; break;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment