Server IP : 104.21.38.3 / Your IP : 108.162.226.168 Web Server : Apache System : Linux krdc-ubuntu-s-2vcpu-4gb-amd-blr1-01.localdomain 5.15.0-142-generic #152-Ubuntu SMP Mon May 19 10:54:31 UTC 2025 x86_64 User : www ( 1000) PHP Version : 7.4.33 Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /www/server/mysql/src/mysql-test/extra/binlog_tests/ |
Upload File : |
source include/have_log_bin.inc; source include/not_embedded.inc; # Checking that the drop of a database does not replicate anything in # addition to the drop of the database reset master; create database testing_1; use testing_1; create table t1 (a int); create function sf1 (a int) returns int return a+1; create trigger tr1 before insert on t1 for each row insert into t2 values (2*new.a); create procedure sp1 (a int) insert into t1 values(a); drop database testing_1; --let $mask_binlog_commit_events= 1 source include/show_binlog_events.inc; --let $mask_binlog_commit_events= 0 # BUG#38773: DROP DATABASE cause switch to stmt-mode when there are # temporary tables open use test; reset master; create temporary table tt1 (a int); create table t1 (a int); insert into t1 values (1); disable_warnings; drop database if exists mysqltest1; enable_warnings; insert into t1 values (1); drop table tt1, t1; --let $mask_binlog_commit_events= 1 source include/show_binlog_events.inc; --let $mask_binlog_commit_events= 0 FLUSH STATUS; --echo --echo # 'DROP TABLE IF EXISTS <deleted tables>' is binlogged --echo # when 'DROP DATABASE' fails and at least one table is deleted --echo # from the database. RESET MASTER; CREATE DATABASE testing_1; USE testing_1; CREATE TABLE t1(c1 INT); CREATE TABLE t2(c1 INT); let $prefix= `SELECT UUID()`; --echo # Create a file in the database directory --replace_result $prefix FAKE_FILE eval SELECT 'hello' INTO OUTFILE 'fake_file.$prefix'; --echo --echo # 'DROP DATABASE' will fail if there is any other file in the the --echo # database directory # Use '/' instead of '\' in the error message. On windows platform, dir is # formed with '\'. --replace_regex /\\testing_1\\*/\/testing_1\// --error 1010 DROP DATABASE testing_1; let $wait_binlog_event= DROP TABLE IF EXIST; source include/wait_for_binlog_event.inc; let $MYSQLD_DATADIR= `SELECT @@datadir`; --echo --echo # Remove the fake file. --remove_file $MYSQLD_DATADIR/testing_1/fake_file.$prefix --echo # Now we can drop the database. DROP DATABASE testing_1; --echo # --echo # Bug#11765416 58381: FAILED DROP DATABASE CAN BREAK STATEMENT --echo # BASED REPLICATION --echo # USE test; --disable_warnings DROP DATABASE IF EXISTS db1; DROP TABLE IF EXISTS t3; --enable_warnings CREATE DATABASE db1; CREATE TABLE db1.t1 (a INT); CREATE TABLE db1.t2 (b INT, KEY(b)) engine=innodb; CREATE TABLE t3 (a INT, KEY (a), FOREIGN KEY(a) REFERENCES db1.t2(b)) engine=innodb; RESET MASTER; --error ER_ROW_IS_REFERENCED DROP DATABASE db1; # Fails because of the fk SHOW TABLES FROM db1; # t1 was dropped, t2 remains --let $mask_binlog_commit_events= 1 --source include/show_binlog_events.inc # Check that the binlog drops t1 --let $mask_binlog_commit_events= 0 # Cleanup DROP TABLE t3; DROP DATABASE db1;