[英]MySQL insert array of hardcoded values
我有一个整数列表,我想要一个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')
这样就可以创建所有可能的组合。
如果存在这样的超级脚本,我一定想知道!
编辑:
我认为我的问题与此类似。
我找到了一个非常有前途的解决方案,它是:
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
有这是我画的灵感来自于类似的例子,但矿中含有较多的combitnations。 我在sql小提琴上运行它,它似乎可以工作。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.