# # Start of 10.7 tests # # # MDEV-28918 Implicit cast from INET6 UNSIGNED works differently on UPDATE vs ALTER # CREATE TABLE t1 (target GEOMETRY DEFAULT POINT(1,1), source INT DEFAULT 0); # Start of type_store_assignment_incompatible.inc SET @sql_mode_save= @@sql_mode; SET @source_type= (SELECT COLUMN_TYPE FROM INFORMATION_SCHEMA.COLUMNS WHERE COLUMN_NAME='source' AND TABLE_NAME='t1' AND TABLE_SCHEMA='test'); SET @target_type= (SELECT COLUMN_TYPE FROM INFORMATION_SCHEMA.COLUMNS WHERE COLUMN_NAME='target' AND TABLE_NAME='t1' AND TABLE_SCHEMA='test'); SET @ignore= CASE WHEN @ignore IS NULL OR @ignore = '' THEN '' WHEN @ignore NOT LIKE ' %' THEN CONCAT(' ',@ignore) ELSE @ignore END; CREATE TABLE t2 LIKE t1; ALTER TABLE t2 ADD id INT NOT NULL PRIMARY KEY FIRST; INSERT INTO t2 VALUES (1,DEFAULT,DEFAULT); SHOW CREATE TABLE t2; Table Create Table t2 CREATE TABLE `t2` ( `id` int(11) NOT NULL, `target` geometry DEFAULT point(1,1), `source` int(11) DEFAULT 0, PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci CREATE TABLE t3 LIKE t2; INSERT INTO t3 VALUES (1, (SELECT source FROM t2 ORDER BY id LIMIT 1), (SELECT source FROM t2 ORDER BY id LIMIT 1)); ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `test`.`t3`.`target` DROP TABLE t3; SET sql_mode=''; CREATE TABLE t3 LIKE t2; ALTER TABLE t3 ENGINE=MyISAM; EXECUTE IMMEDIATE CONCAT('CREATE VIEW v3 AS SELECT id,', IF(@target_type='geometry','AsText(target)','target'), ' AS target,', IF(@source_type='geometry','AsText(source)','source'), ' AS source ', ' FROM t3'); INSERT INTO t3 VALUES (1, (SELECT target FROM t2 ORDER BY id LIMIT 1), (SELECT source FROM t2 ORDER BY id LIMIT 1)), (2, (SELECT source FROM t2 ORDER BY id LIMIT 1), (SELECT source FROM t2 ORDER BY id LIMIT 1)); ERROR 22003: Cannot get geometry object from data you send to the GEOMETRY field SELECT * FROM v3; id target source 1 POINT(1 1) 0 TRUNCATE TABLE t3; SET sql_mode=STRICT_ALL_TABLES; INSERT INTO t3 VALUES (1, (SELECT target FROM t2 ORDER BY id LIMIT 1), (SELECT source FROM t2 ORDER BY id LIMIT 1)), (2, (SELECT source FROM t2 ORDER BY id LIMIT 1), (SELECT source FROM t2 ORDER BY id LIMIT 1)); ERROR 22003: Cannot get geometry object from data you send to the GEOMETRY field SELECT * FROM v3; id target source 1 POINT(1 1) 0 TRUNCATE TABLE t3; SET sql_mode=@sql_mode_save; DROP TABLE t3; DROP VIEW v3; CREATE TABLE t3 LIKE t2; INSERT INTO t3 SELECT id,source,source FROM t2; ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `test`.`t3`.`target` INSERT INTO t3 (id,target,source) SELECT id,source,source FROM t2; ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `test`.`t3`.`target` INSERT INTO t3 VALUES (1,DEFAULT,DEFAULT) ON DUPLICATE KEY UPDATE target=source; ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `test`.`t3`.`target` INSERT INTO t3 (id,target,source) VALUES (1,DEFAULT,DEFAULT) ON DUPLICATE KEY UPDATE target=source; ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `test`.`t3`.`target` INSERT INTO t3 SELECT 1,DEFAULT(t2.target),DEFAULT(t2.source) FROM t2 ON DUPLICATE KEY UPDATE t3.target=t2.source; ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `test`.`t3`.`target` INSERT INTO t3 (id,target,source) SELECT 1,DEFAULT(t2.target),DEFAULT(t2.source) FROM t2 ON DUPLICATE KEY UPDATE t3.target=t2.source; ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `test`.`t3`.`target` UPDATE t3 SET target=source; ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `test`.`t3`.`target` UPDATE t2, t3 SET t3.target=t2.source WHERE t2.id=t3.id; ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `test`.`t3`.`target` SET @alter=CONCAT('ALTER', @ignore, ' TABLE t3 MODIFY target ', @source_type); SELECT @alter; @alter ALTER TABLE t3 MODIFY target int(11) EXECUTE IMMEDIATE @alter; ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `test`.`t3`.`target` DROP TABLE t3; DROP TABLE t2; CREATE PROCEDURE p1() BEGIN DECLARE src int(11) DEFAULT NULL; DECLARE dst geometry DEFAULT NULL; SET dst=src; END; $$ CALL p1; ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `dst` DROP PROCEDURE p1; CREATE FUNCTION f1(a geometry) RETURNS INT RETURN NULL;; SELECT f1((SELECT source FROM t1 ORDER BY source LIMIT 1)); ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `a` DROP FUNCTION f1; CREATE PROCEDURE p1(a geometry) BEGIN END;; CALL p1((SELECT source FROM t1 ORDER BY source LIMIT 1)); ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `a` DROP PROCEDURE p1; CREATE PROCEDURE p1(OUT dst geometry) BEGIN DECLARE src int(11) DEFAULT NULL; SET dst=src; END; $$ CREATE PROCEDURE p2() BEGIN DECLARE dst geometry DEFAULT NULL; CALL p1(dst); END; $$ CALL p2(); ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `dst` SHOW WARNINGS; Level Code Message Error 4078 Cannot cast 'int' as 'geometry' in assignment of `dst` Note 4094 At line 4 in test.p1 Note 4094 At line 4 in test.p2 DROP PROCEDURE p2; DROP PROCEDURE p1; CREATE FUNCTION f1() RETURNS geometry BEGIN DECLARE rc int(11) DEFAULT NULL; RETURN rc; END; $$ SELECT f1(); ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `f1()` DROP FUNCTION f1; CREATE PROCEDURE p1() BEGIN DECLARE src int(11) DEFAULT NULL; DECLARE cur1 CURSOR(t geometry) FOR SELECT * FROM t1 WHERE target=t; OPEN cur1(src); CLOSE cur1; END; $$ CALL p1(); ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `t` DROP PROCEDURE p1; CREATE TABLE t2 LIKE t1; INSERT INTO t2 VALUES (); CREATE PROCEDURE p1() BEGIN DECLARE dst geometry DEFAULT NULL; DECLARE cur2 CURSOR FOR SELECT source FROM t2 ORDER BY source LIMIT 1; OPEN cur2; FETCH cur2 INTO dst; CLOSE cur2; END; $$ CALL p1(); ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `dst` DROP PROCEDURE p1; DROP TABLE t2; # End of type_store_assignment_incompatible.inc DROP TABLE t1; CREATE TABLE t1 (target INT DEFAULT 0, source GEOMETRY DEFAULT POINT(1,1)); # Start of type_store_assignment_incompatible.inc SET @sql_mode_save= @@sql_mode; SET @source_type= (SELECT COLUMN_TYPE FROM INFORMATION_SCHEMA.COLUMNS WHERE COLUMN_NAME='source' AND TABLE_NAME='t1' AND TABLE_SCHEMA='test'); SET @target_type= (SELECT COLUMN_TYPE FROM INFORMATION_SCHEMA.COLUMNS WHERE COLUMN_NAME='target' AND TABLE_NAME='t1' AND TABLE_SCHEMA='test'); SET @ignore= CASE WHEN @ignore IS NULL OR @ignore = '' THEN '' WHEN @ignore NOT LIKE ' %' THEN CONCAT(' ',@ignore) ELSE @ignore END; CREATE TABLE t2 LIKE t1; ALTER TABLE t2 ADD id INT NOT NULL PRIMARY KEY FIRST; INSERT INTO t2 VALUES (1,DEFAULT,DEFAULT); SHOW CREATE TABLE t2; Table Create Table t2 CREATE TABLE `t2` ( `id` int(11) NOT NULL, `target` int(11) DEFAULT 0, `source` geometry DEFAULT point(1,1), PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci CREATE TABLE t3 LIKE t2; INSERT INTO t3 VALUES (1, (SELECT source FROM t2 ORDER BY id LIMIT 1), (SELECT source FROM t2 ORDER BY id LIMIT 1)); ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `test`.`t3`.`target` DROP TABLE t3; SET sql_mode=''; CREATE TABLE t3 LIKE t2; ALTER TABLE t3 ENGINE=MyISAM; EXECUTE IMMEDIATE CONCAT('CREATE VIEW v3 AS SELECT id,', IF(@target_type='geometry','AsText(target)','target'), ' AS target,', IF(@source_type='geometry','AsText(source)','source'), ' AS source ', ' FROM t3'); INSERT INTO t3 VALUES (1, (SELECT target FROM t2 ORDER BY id LIMIT 1), (SELECT source FROM t2 ORDER BY id LIMIT 1)), (2, (SELECT source FROM t2 ORDER BY id LIMIT 1), (SELECT source FROM t2 ORDER BY id LIMIT 1)); Warnings: Warning 1366 Incorrect integer value: '\x00\x00\x00\x00\x01\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\xF0?\x00\x00\x00\x00\x00\x00\xF0?' for column `test`.`t3`.`target` at row 2 SELECT * FROM v3; id target source 1 0 POINT(1 1) 2 0 POINT(1 1) TRUNCATE TABLE t3; SET sql_mode=STRICT_ALL_TABLES; INSERT INTO t3 VALUES (1, (SELECT target FROM t2 ORDER BY id LIMIT 1), (SELECT source FROM t2 ORDER BY id LIMIT 1)), (2, (SELECT source FROM t2 ORDER BY id LIMIT 1), (SELECT source FROM t2 ORDER BY id LIMIT 1)); ERROR 22007: Incorrect integer value: '\x00\x00\x00\x00\x01\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\xF0?\x00\x00\x00\x00\x00\x00\xF0?' for column `test`.`t3`.`target` at row 2 SELECT * FROM v3; id target source 1 0 POINT(1 1) TRUNCATE TABLE t3; SET sql_mode=@sql_mode_save; DROP TABLE t3; DROP VIEW v3; CREATE TABLE t3 LIKE t2; INSERT INTO t3 SELECT id,source,source FROM t2; ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `test`.`t3`.`target` INSERT INTO t3 (id,target,source) SELECT id,source,source FROM t2; ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `test`.`t3`.`target` INSERT INTO t3 VALUES (1,DEFAULT,DEFAULT) ON DUPLICATE KEY UPDATE target=source; ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `test`.`t3`.`target` INSERT INTO t3 (id,target,source) VALUES (1,DEFAULT,DEFAULT) ON DUPLICATE KEY UPDATE target=source; ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `test`.`t3`.`target` INSERT INTO t3 SELECT 1,DEFAULT(t2.target),DEFAULT(t2.source) FROM t2 ON DUPLICATE KEY UPDATE t3.target=t2.source; ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `test`.`t3`.`target` INSERT INTO t3 (id,target,source) SELECT 1,DEFAULT(t2.target),DEFAULT(t2.source) FROM t2 ON DUPLICATE KEY UPDATE t3.target=t2.source; ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `test`.`t3`.`target` UPDATE t3 SET target=source; ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `test`.`t3`.`target` UPDATE t2, t3 SET t3.target=t2.source WHERE t2.id=t3.id; ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `test`.`t3`.`target` SET @alter=CONCAT('ALTER', @ignore, ' TABLE t3 MODIFY target ', @source_type); SELECT @alter; @alter ALTER TABLE t3 MODIFY target geometry EXECUTE IMMEDIATE @alter; ERROR HY000: Cannot cast 'int' as 'geometry' in assignment of `test`.`t3`.`target` DROP TABLE t3; DROP TABLE t2; CREATE PROCEDURE p1() BEGIN DECLARE src geometry DEFAULT NULL; DECLARE dst int(11) DEFAULT NULL; SET dst=src; END; $$ CALL p1; ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `dst` DROP PROCEDURE p1; CREATE FUNCTION f1(a int(11)) RETURNS INT RETURN NULL;; SELECT f1((SELECT source FROM t1 ORDER BY source LIMIT 1)); ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `a` DROP FUNCTION f1; CREATE PROCEDURE p1(a int(11)) BEGIN END;; CALL p1((SELECT source FROM t1 ORDER BY source LIMIT 1)); ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `a` DROP PROCEDURE p1; CREATE PROCEDURE p1(OUT dst int(11)) BEGIN DECLARE src geometry DEFAULT NULL; SET dst=src; END; $$ CREATE PROCEDURE p2() BEGIN DECLARE dst int(11) DEFAULT NULL; CALL p1(dst); END; $$ CALL p2(); ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `dst` SHOW WARNINGS; Level Code Message Error 4078 Cannot cast 'geometry' as 'int' in assignment of `dst` Note 4094 At line 4 in test.p1 Note 4094 At line 4 in test.p2 DROP PROCEDURE p2; DROP PROCEDURE p1; CREATE FUNCTION f1() RETURNS int(11) BEGIN DECLARE rc geometry DEFAULT NULL; RETURN rc; END; $$ SELECT f1(); ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `f1()` DROP FUNCTION f1; CREATE PROCEDURE p1() BEGIN DECLARE src geometry DEFAULT NULL; DECLARE cur1 CURSOR(t int(11)) FOR SELECT * FROM t1 WHERE target=t; OPEN cur1(src); CLOSE cur1; END; $$ CALL p1(); ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `t` DROP PROCEDURE p1; CREATE TABLE t2 LIKE t1; INSERT INTO t2 VALUES (); CREATE PROCEDURE p1() BEGIN DECLARE dst int(11) DEFAULT NULL; DECLARE cur2 CURSOR FOR SELECT source FROM t2 ORDER BY source LIMIT 1; OPEN cur2; FETCH cur2 INTO dst; CLOSE cur2; END; $$ CALL p1(); ERROR HY000: Cannot cast 'geometry' as 'int' in assignment of `dst` DROP PROCEDURE p1; DROP TABLE t2; # End of type_store_assignment_incompatible.inc DROP TABLE t1; # # End of 10.7 tests #