繁体   English   中英

MySQL插入硬编码值数组

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM