Skip to content

Output JSON object as nested objects #1278

@Slyke

Description

@Slyke

Problem:

Setting INTO JSON is returning a flattened JSON object.

Code (NodeJS v12.14):


const alasql = require('alasql');

const data = [
  {
    name: 'item1',
    details: {
      stock: 10,
      purchased: 100
    }
  },
  {
    name: 'item2',
    details: {
      stock: 20,
      purchased: 200
    }
  },
  {
    name: 'item3',
    details: {
      stock: 30,
      purchased: 300
    }
  },
]

const res = alasql(`SELECT name, details->stock INTO JSON() FROM ? WHERE details->stock > 11`, [data]);
console.log(res);

Output:

[{"name":"item2","details->stock":20},{"name":"item3","details->stock":30}]

Expected Output (Formatted):

[{
	"name": "item2",
	"details": {
		"stock": 20
	}
}, {
	"name": "item3",
	"details": {
		"stock": 30
	}
}]

I did read: https://github.com/agershun/alasql/wiki/Json and nothing about options for JSON() like there is for CSV()

Metadata

Metadata

Assignees

Labels

No labels
No labels

Type

No type

Projects

No projects

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions