Return multiple labeled metrics from a single SQL query, each with optional per-metric filters using aggregate FILTER (WHERE …) clauses. Supports all metric types (COUNT, SUM, AVG, MEDIAN, MAX) and optional dimensional grouping (group_by).
Metric param format: metric=<label>,<metric_type>
count, sum:total_funding_usd, percentage:label_a/label_b)Percentage metrics (percentage:numerator/denominator): Computes ROUND(numerator * 100.0 / NULLIF(denominator, 0), 2).
metric=filtered,count&metric=total,count&metric=pct,percentage:filtered/totalPer-metric filters (metric_filter param): metric_filter=<label>:<filter_expression>
filter parammetric_filter=unicorns:is_unicorn[eq]:truemetric_filter=funded:and(total_funding_usd[gte]:100000,is_vc_backed[eq]:true)group_by (optional): Dimension(s) to group by, comma-separated.
sort (optional): Sort by metric label or dimension. Prefix - for descending (default).
limit (optional): Max results when grouped (1-500, default 25).
Post-aggregation filter (metric_having param): Filter grouped rows by metric values.
metric_having=<label>[op]:<value> where op is gt, gte, lt, lte, eq, neqgroup_by is presentmetric_having=percentage[gt]:25&metric_having=filtered[gte]:5Shared filters (filter param): Uses structured AST syntax, same as /api/aggregate/:source.
filter=tag_id[eq]:42filter=and(tag_id[eq]:42,launch_year[gte]:2020)filter=or(location[eq]:133,location[eq]:75)Example — mixed metrics with group_by:
GET /api/aggregate/companies/multi-metric
?metric=total,count
&metric=unicorns,count
&metric=unicorn_funding,sum:total_funding_usd
&metric_filter=unicorns:is_unicorn[eq]:true
&metric_filter=unicorn_funding:is_unicorn[eq]:true
&group_by=hq_country
&sort=-total
&limit=10
&filter=launch_year[gte]:2015
Example — flat (no group_by):
GET /api/aggregate/companies/multi-metric
?metric=total,count
&metric=unicorns,count
&metric=unicorn_funding,sum:total_funding_usd
&metric_filter=unicorns:is_unicorn[eq]:true
&metric_filter=unicorn_funding:is_unicorn[eq]:true
Returns: { data: { total: 52341, unicorns: 1287, unicorn_funding: 3400000000000 }, query_info: { source: "companies", metrics: [...] } }
Auth0 JWT access token
The source to aggregate
founders, investors, companies, funding-rounds, valuations, entities, fundings "companies"
Metric definition: label,metric_type. Repeat for multiple metrics. Types: count, count_distinct:field, sum:field, avg:field, median:field, p25:field, p75:field, percentage:numerator_label/denominator_label. Example: metric=total,count&metric=unicorns,count&metric=pct,percentage:unicorns/total
1"total,count"
Per-metric filter expression:
1"unicorns:is_unicorn[eq]:true"
Post-aggregation filter:
1"percentage[gt]:25"
Dimension(s) to group by, comma-separated. Omit for flat aggregation
1^[a-z][a-z0-9_.]*(?:,[a-z][a-z0-9_.]*)*$"hq_country"
Filter expression: and(key[op]:value,...), or(...). Example: and(tag_id[eq]:42,launch_year[gte]:2020)
"and(tag_id[eq]:42,launch_year[gte]:2020)"
Sort by metric label or 'dimension'. Prefix with - for descending
^-?[a-z][a-z0-9_]*$"-total"
Number of results to return (1-500, default 25)
"25"