Enabled resource errors field for orders and carts —
Check the use case
LogoLogo
Metrics APIOther APIsChangelog
Getting started
Getting started
  • Welcome to Metrics API
  • Getting started
    • API specification
    • Queries
      • Breakdown
      • Date breakdown
      • Stats
      • Search
    • Filters
    • Analysis
      • FBT
    • Errors
    • Use cases
      • Orders by currency
      • Orders by status and payment status
      • Orders by repeat customer
      • Orders by bundle
      • Orders by shipment status and shipping method name
      • Orders paid with gift cards
      • Orders associated with a specific promotion
      • Number of products per order by country
      • Best-selling products by market
      • Customers that bought a specific product
      • Shipments average time in picking
      • Top 10 spenders by currency
      • Orders by day
      • Returns per year by destination city
      • Refunds by country and currency
      • Latest carts with a specific product from a specific market
      • Orders by resource error code and message
      • Latest archived orders
      • Latest placed orders from customers with specific email domains
      • Frequently bought together products
  • API reference
    • Orders
    • Returns
    • Carts
On this page
  • The problem
  • The solution
  • Try it on Postman
  • Example
  • Similar cases
  1. Getting started
  2. Use cases

Number of products per order by country

How to use the Metrics API to get mixed stats about the number of SKUs included in the orders of your organization, grouped by different countries

PreviousOrders associated with a specific promotionNextBest-selling products by market

Last updated 8 days ago

The problem

You want to get some common statistics about the number of SKUs present in your organization's orders over a selected date and time range, grouped by the different countries you're selling in. Specifically:

Stat
Description

count

The total number of orders considered for the computation.

max

The minimum number of SKUs included in a single order.

min

The maximum number of SKUs included in a single order.

avg

The average number of SKUs included in a single order.

sum

The sum of all the SKUs included in the orders considered for the computation.

The solution

Query

You need to perform a breakdown query setting the required query keys as follows and adding the optional ones based on your needs:

Key
Value

by

order.country_code

field

order.skus_count

operator

stats

Filter

Make sure to set the desired date and time range using the date_from and date_to keys in the filter.

In the example below, since the date_field isn't specified in the date filter, the default value current_date will be used, meaning that the results will count all the orders that changed their status within the selected date and time range (read more about this).

Try it on Postman

Example

The following request uses the Metrics API to get mixed stats about the number of SKUs included in your orders, groped by country:

curl -g -X POST \
  'https://{{your_domain}}.commercelayer.io/metrics/orders/breakdown' \
  -H 'Accept: application/vnd.api.v1+json' \
  -H 'Content-Type: application/vnd.api+json' \
  -H 'Authorization: Bearer {{your_access_token}}' \
  -d '{
    "breakdown": {
      "by": "order.country_code",
      "field": "order.skus_count",
      "operator": "stats",
      "sort": "desc",
      "limit": 20
    },
    "filter": {
      "order": {
        "date_from": "2021-01-01T00:00:00Z",
        "date_to": "2021-12-31T23:59:00Z"
      }
    }
  }'

On success, the API responds with a 200 OK status code, returning the aggregated, nested values in the data object and extra information in the meta object:

{
  "data": {
    "order.country_code": [
      {
        "label": "US",
        "value": {
          "count": 1993,
          "min": 1.0,
          "max": 23,
          "avg": 3.51,
          "sum": 6998.0
        }
      },
      {
        "label": "GB",
        "value": {
          "count": 8991,
          "min": 1.0,
          "max": 14,
          "avg": 2.1,
          "sum": 18881.0
        }
      },
      {
        "label": "IT",
        "value": {
          "count": 25676,
          "min": 1.0,
          "max": 10.0,
          "avg": 1.87,
          "sum": 48270.0
        }
      },
      { ... }
    ]
  },
  "meta": {
    "type": "stats",
    "trace_id": "fe571ea2-8a4f-4a5e-bd26-ac54651bb2e4",
    "mode": "test",
    "organization_id": "xYZkjABcde",
    "market_ids": [ "yzXKjYzaCx", "..." ]
  }
}

Similar cases

Just changing a couple of query keys and/or filter parameters you can address lots of very similar use cases, such as:

  • Total number of orders by country code

  • Total number of tagged orders by tag name

  • Total number of orders by market name

  • Total number of orders by shipping address city

  • Total number of orders by repeat customer

  • Total number of orders by bundle name

  • Total number of orders by customer email associated with a specific coupon

  • Total number of orders with a specific personalization option

  • Total number of orders by currency code

🚀