Трябва да промените размера на VARCHAR на максималната му стойност (или по-ниска значима стойност).
DELIMITER //
CREATE PROCEDURE deleteObjectTypes(IN p_type VARCHAR(65535))
BEGIN
SET @query = CONCAT ('DELETE FROM object WHERE Type NOT IN (',p_type,')');
PREPARE stmt FROM @query;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
END //
DELIMITER ;
Имайте предвид обаче, че ограничението е по-ниско, ако използвате многобайтов набор от знаци:
VARCHAR(21844) CHARACTER SET utf8
Както се вижда тук .