MySQL插入硬编码值数组

标签 mysql

我有一个整数列表,我想要一个将所有整数添加为特定列的 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/

相关文章:

php - MySql查询: don't wait for result

php - 分割一个巨大的表

mysql - 如何编写查询以从数据库表中获取最近的记录

mysql - 如何在 MySQL 中使用 IN 子句和 zerofill 字段选择行

mysql - 优化sql请求统计

php - 如何将大型维基百科 sql 文件导入 mysql 数据库?

php - fatal error ,不太清楚为什么?

java - mysql日期语法问题

mysql - 优化 mysql 查询前 10 个 View

mysql - SQL - 多个多对多关系过滤 SELECT