我有以下架构。
DROP TABLE IF EXISTS REF_CONNECTION1;
CREATE TABLE REF_CONNECTION1 (
BPIN INT(11) DEFAULT NULL,
RIN INT(11) DEFAULT NULL,
SRC_RIN INT(11) DEFAULT NULL,
PRIMARY KEY (BPIN,RIN,SRC_RIN)
);
INSERT INTO REF_CONNECTION1 VALUE(14,1,2);
INSERT INTO REF_CONNECTION1 VALUE(14,1,3);
INSERT INTO REF_CONNECTION1 VALUE(14,1,4);
INSERT INTO REF_CONNECTION1 VALUE(14,1,5);
INSERT INTO REF_CONNECTION1 VALUE(14,1,6);
INSERT INTO REF_CONNECTION1 VALUE(14,1,7);
SET @S1 = '2,3,4';
SELECT * FROM REF_CONNECTION1 WHERE SRC_RIN IN (@S1);
结果集只给出 1 行,但它应该给出 3 行。我理解它为什么会发生,因为它实际上正在转换为以下查询
SELECT * FROM REF_CONNECTION1 WHERE SRC_RIN IN ('2,3,4');
但我希望它看起来像以下查询。
SELECT * FROM REF_CONNECTION1 WHERE SRC_RIN IN (2,3,4);
我怎样才能做到这一点?非常感谢任何帮助。