我在MariaDb中创建了一个包含动态列的表,如下所示:

CREATE TABLE items (
 id INT NOT NULL PRIMARY KEY AUTO_INCREMENT,
 product varchar(100) NOT NULL,
 data BLOB
);

INSERT INTO items (product, data) VALUES
 ('test_row',
  COLUMN_CREATE('colour', 'blue',
                'details',COLUMN_CREATE('key1','value1','key2','value2'))
 );

但是我无法以JSON格式提取嵌套对象,当我执行以下查询时,会得到某种二进制输出的详细信息字段:
SELECT product, COLUMN_GET(data, 'details' as CHAR(200)) AS Details
FROM items;

如何使用SQL查询解码此字段数据?

最佳答案

使用此查询:

SELECT `product`, COLUMN_JSON(COLUMN_GET(`data`, 'details' AS BINARY)) AS Details
FROM `items`;

关于mysql - 从Mariadb中的动态列字段中提取嵌套对象,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/32266832/

10-12 23:29