Commit 41eb82fd authored by unknown's avatar unknown

Merge gbichot@bk-internal.mysql.com:/home/bk/mysql-4.1

into mysql.com:/home/mysql_src/mysql-4.1-clean
parents cd53739f 2a046c6c
...@@ -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