我有一个表,如:
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作为字符串传递给此参数,并将每个对象作为表中的一行插入
答案 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。