- 
                Notifications
    You must be signed in to change notification settings 
- Fork 686
How to count total with two criteria
        agershun edited this page Dec 28, 2014 
        ·
        1 revision
      
    Source: StackOverflow.com
How to count the total devices based on location and unique serial number.
    {
    "dates": [
        {
            "date": "Sep 1, 2014",
            "devices": [
                {
                    "model": "Canon",
                    "location": "Chicago",
                    "serialNum": "abc123"
                },
                {
                    "model": "Canon",
                    "location": "Chicago",
                    "serialNum": "xyz456"
                },
                {
                    "model": "HP",
                    "location": "New York",
                    "serialNum": "123456"
                },
                {
                    "model": "Brother",
                    "location": "Chicago",
                    "serialNum": "DEF777"
                }
            ]
        },
        {
            "date": "Sep 2, 2014",
            "devices": [
                {
                    "model": "Canon",
                    "location": "Chicago",
                    "serialNum": "abc123"
                },
                {
                    "model": "Canon",
                    "location": "Chicago",
                    "serialNum": "xyz456"
                }
            ]
        },
        {
            "date": "Sep 3, 2014",
            "devices": [
                {
                    "model": "Canon",
                    "location": "Chicago",
                    "serialNum": "xyz456"
                },
                {
                    "model": "Canon",
                    "location": "Chicago",
                    "serialNum": "stu789"
                },
                {
                    "model": "Epson",
                    "location": "NewYork",
                    "serialNum": "123456"
                },
                {
                    "model": "Epson",
                    "location": "NewYork",
                    "serialNum": "555555"
                },
                {
                    "model": "HP",
                    "location": "NewYork",
                    "serialNum": "987654"
                }
            ]
        }
    ]
}I would like to capture the total number of unique devices per location Chicago - 4 New York - 3
    var data = {...};
    // User-defined aggregator to concat arrays
    alasql.aggr.CONCAT = function(v,s) {
        return (s||[]).concat(v);
    };
    var res = alasql('SELECT location, COUNT(model) AS qty FROM \
                         (SELECT location, model FROM \
                             (SELECT VALUE CONCAT(devices) FROM ?) \
                         GROUP BY location, model) \
                      GROUP BY location',[data.dates]);Try this example at jsFiddle.
© 2014-2024, Andrey Gershun & Mathias Rangel Wulff
Please help improve the documentation by opening a PR on the wiki repo