mirror of
https://github.com/MariaDB/server.git
synced 2025-07-27 18:02:13 +03:00
MDEV-29540 Incorrect sequence values in INSERT SELECT
The population of default values in INSERT SELECT was being performed twice. With sequences, this resulted in every second sequence value being used. With SELECT INSERT we remove the second invokation of table->update_default_fields(). This was already performed in store_values() invoking fill_record_n_invoke_before_triggers() which invoked update_default_fields() previously. We do need to return an error on duplicate values, so the ::store_values is extended to take the ignore option.
This commit is contained in:
@ -135,3 +135,83 @@ EXECUTE stmt;
|
||||
# Cleanup
|
||||
DROP TABLE t1;
|
||||
DROP SEQUENCE s;
|
||||
|
||||
--echo #
|
||||
--echo # MDEV-29540 Incorrect sequence values in INSERT SELECT
|
||||
--echo #
|
||||
|
||||
CREATE SEQUENCE s1;
|
||||
CREATE TABLE t1 (
|
||||
a BIGINT UNSIGNED NOT NULL PRIMARY KEY
|
||||
DEFAULT (NEXT VALUE FOR s1),
|
||||
b CHAR(1) NOT NULL
|
||||
);
|
||||
|
||||
INSERT INTO t1 (b) VALUES ('a');
|
||||
INSERT INTO t1 (b) VALUES ('b'), ('c');
|
||||
INSERT INTO t1 (b) VALUES ('d');
|
||||
INSERT INTO t1 (b) SELECT c FROM (
|
||||
SELECT 'e' as c
|
||||
UNION
|
||||
SELECT 'f'
|
||||
UNION
|
||||
SELECT 'g'
|
||||
) der;
|
||||
|
||||
SELECT a, b FROM t1;
|
||||
|
||||
ALTER SEQUENCE s1 RESTART;
|
||||
|
||||
--error ER_DUP_ENTRY
|
||||
INSERT INTO t1 (b) SELECT c FROM (
|
||||
SELECT 'a' as c
|
||||
UNION
|
||||
SELECT 'b'
|
||||
UNION
|
||||
SELECT 'c'
|
||||
UNION
|
||||
SELECT 'd'
|
||||
UNION
|
||||
SELECT 'e'
|
||||
UNION
|
||||
SELECT 'f'
|
||||
UNION
|
||||
SELECT 'g'
|
||||
) der;
|
||||
|
||||
ALTER SEQUENCE s1 RESTART;
|
||||
|
||||
INSERT IGNORE INTO t1 (b) SELECT c FROM (
|
||||
SELECT 'a' as c
|
||||
UNION
|
||||
SELECT 'b'
|
||||
UNION
|
||||
SELECT 'c'
|
||||
UNION
|
||||
SELECT 'd'
|
||||
UNION
|
||||
SELECT 'e'
|
||||
UNION
|
||||
SELECT 'f'
|
||||
UNION
|
||||
SELECT 'g'
|
||||
) der;
|
||||
|
||||
SELECT a, b FROM t1;
|
||||
|
||||
INSERT IGNORE INTO t1 (b) SELECT c FROM (
|
||||
SELECT 'h' as c
|
||||
UNION
|
||||
SELECT 'i'
|
||||
UNION
|
||||
SELECT 'j'
|
||||
) der;
|
||||
|
||||
SELECT a, b FROM t1;
|
||||
|
||||
DROP TABLE t1;
|
||||
DROP SEQUENCE s1;
|
||||
|
||||
--echo #
|
||||
--echo # End of 10.3 tests
|
||||
--echo #
|
||||
|
Reference in New Issue
Block a user