Server IP : 104.21.38.3 / Your IP : 162.158.106.156 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/ndb/r/ |
Upload File : |
create table parent ( a int primary key auto_increment, b int not null, c int not null, unique(b) using hash, index(c)) engine = ndb; create table child ( a int primary key auto_increment, b int, c int, unique(b) using hash, index(c)) engine = ndb; Warnings: Warning 1121 Ndb does not support unique index on NULL valued attributes, index access with NULL value will become full table scan alter table child add constraint fkname foreign key (b) references parent (a) on update restrict on delete set null; insert into parent values (1,1,1),(2,2,2); insert into child values (1,1,1),(2,2,2); insert into child values (3,3,3); ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (Unknown error code) update child set b = 3 where a = 1; ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (Unknown error code) begin; delete from parent where a = 1; select * from child order by 1,2,3; a b c 1 NULL 1 2 2 2 commit; delete from child; delete from parent; alter table child drop foreign key fkname; alter table child add constraint fkname foreign key (c) references parent (a) on update restrict on delete set null; insert into parent values (1,1,1),(2,2,2); insert into child values (1,1,1),(2,2,2),(3,3,1); update child set c = 3 where a = 1; ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (Unknown error code) insert into child values (4,4,4); ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (Unknown error code) begin; delete from parent where a = 1; select * from child order by 1,2,3; a b c 1 1 NULL 2 2 2 3 3 NULL commit; delete from child; delete from parent; alter table child drop foreign key fkname; alter table child add constraint fkname foreign key (b) references parent (b) on update set null on delete set null; insert into parent values (1,1,1),(2,2,2); insert into child values (1,1,1),(2,2,2); update child set b = 3 where a = 1; ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (Unknown error code) insert into child values (3,3,3); ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (Unknown error code) begin; update parent set b = 3 where a = 1; select * from child order by 1,2,3; a b c 1 NULL 1 2 2 2 rollback; begin; delete from parent where a = 1; select * from child order by 1,2,3; a b c 1 NULL 1 2 2 2 commit; delete from child; delete from parent; alter table child drop foreign key fkname; alter table child add constraint fkname foreign key (c) references parent (b) on update set null on delete set null; insert into parent values (1,1,1),(2,2,2); insert into child values (1,1,1),(2,2,2),(3,3,1); update child set c = 3 where a = 1; ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (Unknown error code) insert into child values (4,4,4); ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (Unknown error code) begin; update parent set b = 3 where a = 1; select * from child order by 1,2,3; a b c 1 1 NULL 2 2 2 3 3 NULL rollback; begin; delete from parent where a = 1; select * from child order by 1,2,3; a b c 1 1 NULL 2 2 2 3 3 NULL commit; delete from child; delete from parent; alter table child drop foreign key fkname; drop table parent, child;