MySQL 自动从通配符 SELECT 构建 JSON_OBJECT?

Lar*_*ars 4 mysql mysql-json

不幸的是,MySQL 不提供类似的功能

SELECT JSON_OBJECT(*) FROM table
Run Code Online (Sandbox Code Playgroud)

现在我想知道是否有人已经编写了执行此任务的函数。我想要实现的是SELECT *从任何返回JSON_OBJECT.

当然,可以为每个给定的表手动创建它。但我正在寻找一种更通用的方法,不需要手动指定所有列。

Bil*_*win 8

如果没有动态 SQL,您就无法做到这一点。JSON_OBJECT()接受的参数必须是固定的键/值对。如果您想要一个JSON_OBJECT()为表的每一列生成键的表达式,请查阅 INFORMATION_SCHEMA 并生成表达式列表,然后在动态 SQL 查询中使用该列表。

例子:

mysql> create table mytable (id serial primary key, name text, created_at datetime);

mysql> insert into mytable set name='Bill', created_at=NOW();

mysql> select * from mytable;
+----+------+---------------------+
| id | name | created_at          |
+----+------+---------------------+
|  1 | Bill | 2021-09-19 17:37:05 |
+----+------+---------------------+

mysql> select concat('select json_object(',
    group_concat(concat(quote(column_name), ', ', column_name)), 
    ') from mytable;') into @sql 
  from information_schema.columns 
  where table_schema = 'test' and table_name = 'mytable';


mysql> select @sql;
+----------------------------------------------------------------------------------+
| @sql                                                                             |
+----------------------------------------------------------------------------------+
| select json_object('id', id,'name', name,'created_at', created_at) from mytable; |
+----------------------------------------------------------------------------------+


mysql> prepare stmt from @sql;

mysql> execute stmt;
+-----------------------------------------------------------------------+
| json_object("id", id,"name", name,"created_at", created_at)           |
+-----------------------------------------------------------------------+
| {"id": 1, "name": "Bill", "created_at": "2021-09-19 17:37:05.000000"} |
+-----------------------------------------------------------------------+
Run Code Online (Sandbox Code Playgroud)