我有一个整数列表,我想要一个将所有整数添加为特定列的 INSERT。我的想法是,我可以避免使用多个 INSERT,或者可以避免使用 SQL FOR LOOP。
这是我尝试过的:
INSERT INTO my_table
(id, number, text)
SELECT array_id, 5, 'Text'
WHERE array_id = (SELECT 9,14,19,39,58,15,1,59,40,20,17,69,12,42,22,2,57,1,8,4)
或者
WHERE array_id IN (9,14,19,39,58,15,1,59,40,20,17,69,12,42,22,2,57,1,8,4)
还有其他各种事情,
有没有快速的方法来做到这一点?
同一问题的 B 部分是添加列表的组合,如下所示:
INSERT INTO my_table
(id, number, text)
SELECT array_id, array_number, array_text
WHERE array_id = (SELECT 9,14,19,39,58,15,1,59,40,20,17,69,12,42,22,2,57,1,8,4)
AND array_number = (SELECT 1,2,3)
AND array_text = (SELECT 'Text A', 'Text B')
这样它就可以创建所有可能的组合。
如果存在这样的 super 脚本,我绝对想知道它!
编辑:
我认为我的问题类似于 this here .
最佳答案
我找到了一个非常有前途的解决方案:
INSERT INTO my_table
(id, number, text)
SELECT array_id, array_number, array_text
FROM (SELECT 9 AS array_id UNION
SELECT 14 UNION
SELECT 19 UNION
SELECT 39 UNION
SELECT 58 UNION
SELECT 15 UNION
SELECT 1 UNION
SELECT 59 UNION
SELECT 40 UNION
SELECT 20 UNION
SELECT 17 UNION
SELECT 69 UNION
SELECT 12 UNION
SELECT 42 UNION
SELECT 22 UNION
SELECT 2 UNION
SELECT 57 UNION
SELECT 1 UNION
SELECT 8 UNION
SELECT 4 ) xx
CROSS JOIN (SELECT 1 AS array_number
UNION SELECT 2
UNION SELECT 3
) yy
CROSS JOIN (SELECT 'Text A' AS array_text UNION
SELECT 'Text B' UNION
SELECT 'Text C') zz
有this我从中汲取了灵感的类似示例,但我的包含更多组合。我在 sql fiddle 上运行它,它似乎可以工作。
关于MySQL插入硬编码值数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23811432/