File: binlog_innodb_stm.test

package info (click to toggle)
mariadb 1%3A11.8.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 772,520 kB
  • sloc: ansic: 2,414,714; cpp: 1,791,394; asm: 381,336; perl: 62,905; sh: 49,647; pascal: 40,897; java: 39,363; python: 20,791; yacc: 20,432; sql: 17,907; xml: 12,344; ruby: 8,544; cs: 6,542; makefile: 6,145; ada: 1,879; lex: 1,193; javascript: 996; objc: 80; tcl: 73; awk: 46; php: 22
file content (40 lines) | stat: -rw-r--r-- 1,144 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
source include/have_innodb.inc;
source include/have_binlog_format_statement.inc;

#
# MDEV-18466 Unsafe to log updates on tables referenced by foreign keys with triggers in statement format
#

create table categories(
   cat_id int not null primary key,
   cat_name varchar(255) not null,
   cat_description text
) engine=innodb;
 
create table products(
   prd_id int not null auto_increment primary key,
   prd_name varchar(355) not null,
   prd_price decimal,
   cat_id int not null,
   foreign key fk_cat(cat_id)
   references categories(cat_id)
   on update cascade
) engine=innodb;

insert into categories values (1, 'drinks', 'drinks');
update categories set cat_description=2 where cat_id=1;
drop table products, categories;


--echo #
--echo # MDEV-35081 - Assertion `!n_mysql_tables_in_use' failed after error
--echo #              upon binary logging of DML involving vector table
--echo #
SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;
CREATE TABLE t (pk INT PRIMARY KEY, v VECTOR(1) NOT NULL, VECTOR(v)) ENGINE=InnoDB;

--error ER_BINLOG_STMT_MODE_AND_ROW_ENGINE
UPDATE t SET pk = 2 WHERE pk = 1;

# Cleanup
DROP TABLE t;