Server IP : 104.21.38.3 / Your IP : 162.158.88.124 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/suite/innodb/t/ |
Upload File : |
-- source include/not_embedded.inc -- source include/have_innodb.inc --disable_warnings drop table if exists t1; --enable_warnings # basic tests of semi-consistent reads connect (a,localhost,root,,); connect (b,localhost,root,,); connection a; set binlog_format=mixed; set session transaction isolation level repeatable read; create table t1(a int not null) engine=innodb DEFAULT CHARSET=latin1; insert into t1 values (1),(2),(3),(4),(5),(6),(7); set autocommit=0; # this should lock the entire table select * from t1 where a=3 lock in share mode; connection b; set binlog_format=mixed; set session transaction isolation level repeatable read; set autocommit=0; -- error ER_LOCK_WAIT_TIMEOUT update t1 set a=10 where a=5; commit; connection a; commit; connection b; # perform a semi-consisent read (and unlock non-matching rows) set session transaction isolation level read committed; update t1 set a=10 where a=5; connection a; -- error ER_LOCK_WAIT_TIMEOUT select * from t1 where a=2 for update; # this should lock the records (1),(2) select * from t1 where a=2 limit 1 for update; connection b; # semi-consistent read will skip non-matching locked rows a=1, a=2 update t1 set a=11 where a=6; -- error ER_LOCK_WAIT_TIMEOUT update t1 set a=12 where a=2; -- error ER_LOCK_WAIT_TIMEOUT update t1 set a=13 where a=1; connection a; commit; connection b; update t1 set a=14 where a=1; commit; connection a; select * from t1; drop table t1; connection default; disconnect a; disconnect b; # Bug 39320 create table t1 (a int, b int) engine=myisam; create table t2 (c int, d int, key (c)) engine=innodb; insert into t1 values (1,1); insert into t2 values (1,2); connect (a,localhost,root,,); connection a; set session transaction isolation level read committed; delete from t1 using t1 join t2 on t1.a = t2.c where t2.d in (1); connection default; disconnect a; drop table t1, t2;