mirror of
https://github.com/MariaDB/server.git
synced 2025-10-24 07:13:33 +03:00

The patch for WL 1563 added a new duplicate key error message so that the key name could be provided instead of the key number. But the error code for the new message was used even though that did not need to change. This could cause unnecessary problems for applications that used the old ER_DUP_ENTRY error code to detect duplicate key errors.
48 lines
1.2 KiB
Plaintext
48 lines
1.2 KiB
Plaintext
#
|
|
# Test of REPLACE with MyISAM and HEAP
|
|
#
|
|
|
|
--disable_warnings
|
|
drop table if exists t1;
|
|
--enable_warnings
|
|
|
|
CREATE TABLE t1 (
|
|
gesuchnr int(11) DEFAULT '0' NOT NULL,
|
|
benutzer_id int(11) DEFAULT '0' NOT NULL,
|
|
PRIMARY KEY (gesuchnr,benutzer_id)
|
|
);
|
|
|
|
replace into t1 (gesuchnr,benutzer_id) values (2,1);
|
|
replace into t1 (gesuchnr,benutzer_id) values (1,1);
|
|
replace into t1 (gesuchnr,benutzer_id) values (1,1);
|
|
alter table t1 engine=heap;
|
|
replace into t1 (gesuchnr,benutzer_id) values (1,1);
|
|
drop table t1;
|
|
|
|
#
|
|
# Test when using replace on a key that has used up it's whole range
|
|
#
|
|
|
|
create table t1 (a tinyint not null auto_increment primary key, b char(20) default "default_value");
|
|
insert into t1 values (126,"first"),(63, "middle"),(0,"last");
|
|
--error ER_DUP_ENTRY
|
|
insert into t1 values (0,"error");
|
|
--error ER_DUP_ENTRY
|
|
replace into t1 values (0,"error");
|
|
replace into t1 values (126,"first updated");
|
|
replace into t1 values (63,default);
|
|
select * from t1;
|
|
drop table t1;
|
|
|
|
# End of 4.1 tests
|
|
|
|
#
|
|
# Bug#19789: REPLACE was allowed for a VIEW with CHECK OPTION enabled.
|
|
#
|
|
CREATE TABLE t1 (f1 INT);
|
|
CREATE VIEW v1 AS SELECT f1 FROM t1 WHERE f1 = 0 WITH CHECK OPTION;
|
|
--error 1369
|
|
REPLACE INTO v1 (f1) VALUES (1);
|
|
DROP TABLE t1;
|
|
DROP VIEW v1;
|