将记录从JSONArray插入MySQL表

时间:2018-06-19 17:44:39

标签: mysql sql json mariadb

我有一个表,如:

CREATE TABLE `mydb`.`mytable` (
  `id` INT NOT NULL,
  `name` VARCHAR(50) NULL,
  PRIMARY KEY (`id`));

和这样的JASONArray:

[{"id":1, "name":"X"}, {"id":2, "name":"Y"},{"id":3,"name":"Z"}]

是否可以从数组中提取每个JSONObject并将其插入到表中?或类似的东西:

Insert Into mytable Select From JSON_EXTRACT(@JsonArray, '?')

我应该用什么代替“?”在JASON_Extract函数中标记?

我有一个带Varchar参数的存储过程,我想将JSONArray作为字符串传递给此参数,并将每个对象作为表中的一行插入

1 个答案:

答案 0 :(得分:0)

您可以通过使用JSON_VALUE并遍历数组来做到这一点:

CREATE OR REPLACE TABLE t1(id INT, name VARCHAR(100));

DELIMITER // ;

CREATE OR REPLACE PROCEDURE p(IN json TEXT)
BEGIN
    -- Our loop variable                                                                                                                                                                      
    DECLARE i INT DEFAULT 0;
    -- How long our JSON array is                                                                                                                                                             
    DECLARE e INT DEFAULT JSON_LENGTH(json);

    WHILE i < e DO
        -- Get the values at array offset `i` and insert them into the table                                                                                                                  
        INSERT INTO t1 VALUES (JSON_VALUE(json, CONCAT('$[', i, '].id')), JSON_VALUE(json, CONCAT('$[', i, '].name')));
        -- Increment the loop variable                                                                                                                                                        
        SET i = i + 1;
    END WHILE;
END //

DELIMITER ; //

-- Call the procedure and examine results                                                                                                                                                     
SET @json := '[{"id":1, "name":"X"}, {"id":2, "name":"Y"},{"id":3,"name":"Z"}]';
CALL p(@json);
SELECT * FROM t1;

另一种选择是使用SEQUENCE引擎和INSERT SELECT

INSERT INTO t1 SELECT
       JSON_VALUE(@json, CONCAT('$[', seq, '].id')) AS id,
       JSON_VALUE(@json, CONCAT('$[', seq, '].name')) AS name
FROM seq_0_to_1000000
WHERE seq < JSON_LENGTH(@json);

使用seq_0_to_1000000并不是很整洁。使用MariaDB,您可以use the compound statements outside of stored procedures