Cost Per Acquisition (CPA)
Average cost to acquire a new customer or achieve a specific conversion goal
Overview
Cost Per Acquisition (CPA) measures the average cost to acquire a new customer or achieve a specific conversion goal. It's a fundamental metric for evaluating marketing campaign effectiveness and determining the profitability of different acquisition channels.
CPA helps businesses optimize their marketing spend by identifying the most cost-effective channels and campaigns. When compared to customer lifetime value, it provides crucial insights into the sustainability and profitability of customer acquisition strategies.
CPA = Total Marketing Spend / Number of Acquisitions
                        CPA vs CAC vs CPL
CPA: Cost per specific action (purchase, signup, etc.)
                            CAC: Cost per paying customer (subset of CPA)
                            CPL: Cost per lead (earlier funnel stage)
Why It Matters
- Budget Optimization: Allocate marketing spend to most efficient channels
- Campaign Performance: Measure and compare effectiveness across campaigns
- Profitability Analysis: Ensure acquisition costs don't exceed customer value
- Channel Comparison: Identify best-performing acquisition channels
- Scaling Decisions: Determine which campaigns to scale up or down
- ROI Calculation: Calculate return on marketing investment
How to Measure It
Calculate CPA by dividing total marketing costs by the number of acquisitions, with proper attribution and time window considerations.
Basic CPA Calculation by Channel
-- Calculate CPA by marketing channel
WITH marketing_spend AS (
  SELECT 
    DATE_TRUNC('month', spend_date) as month,
    channel,
    campaign_type,
    SUM(cost) as total_spend
  FROM marketing_costs
  WHERE spend_date >= '2024-01-01'
  GROUP BY 1, 2, 3
),
acquisitions AS (
  SELECT 
    DATE_TRUNC('month', conversion_date) as month,
    acquisition_channel as channel,
    campaign_type,
    COUNT(*) as total_acquisitions,
    SUM(first_purchase_value) as acquisition_revenue
  FROM customers
  WHERE conversion_date >= '2024-01-01'
    AND acquisition_channel IS NOT NULL
  GROUP BY 1, 2, 3
)
SELECT 
  s.month,
  s.channel,
  s.campaign_type,
  s.total_spend,
  COALESCE(a.total_acquisitions, 0) as acquisitions,
  ROUND(s.total_spend / NULLIF(a.total_acquisitions, 0), 2) as cpa,
  ROUND(a.acquisition_revenue / NULLIF(a.total_acquisitions, 0), 2) as avg_acquisition_value,
  ROUND((a.acquisition_revenue - s.total_spend) / NULLIF(s.total_spend, 0) * 100, 2) as roi_percent
FROM marketing_spend s
LEFT JOIN acquisitions a ON s.month = a.month 
  AND s.channel = a.channel 
  AND s.campaign_type = a.campaign_type
ORDER BY s.month DESC, cpa ASC;CPA with Attribution Windows
-- Calculate CPA with different attribution windows
WITH spend_by_window AS (
  SELECT 
    channel,
    campaign_id,
    SUM(cost) as total_spend,
    COUNT(DISTINCT DATE_TRUNC('day', spend_date)) as active_days
  FROM marketing_costs
  WHERE spend_date >= CURRENT_DATE - INTERVAL '90 days'
  GROUP BY 1, 2
),
conversions_7day AS (
  SELECT 
    acquisition_channel as channel,
    campaign_id,
    COUNT(*) as conversions_7d
  FROM customers
  WHERE conversion_date >= CURRENT_DATE - INTERVAL '90 days'
    AND EXTRACT(days FROM AGE(conversion_date, first_touch_date)) <= 7
  GROUP BY 1, 2
),
conversions_30day AS (
  SELECT 
    acquisition_channel as channel,
    campaign_id,
    COUNT(*) as conversions_30d
  FROM customers
  WHERE conversion_date >= CURRENT_DATE - INTERVAL '90 days'
    AND EXTRACT(days FROM AGE(conversion_date, first_touch_date)) <= 30
  GROUP BY 1, 2
)
SELECT 
  s.channel,
  s.campaign_id,
  s.total_spend,
  COALESCE(c7.conversions_7d, 0) as conversions_7day,
  COALESCE(c30.conversions_30d, 0) as conversions_30day,
  ROUND(s.total_spend / NULLIF(c7.conversions_7d, 0), 2) as cpa_7day,
  ROUND(s.total_spend / NULLIF(c30.conversions_30d, 0), 2) as cpa_30day,
  ROUND((c30.conversions_30d - c7.conversions_7d)::FLOAT / NULLIF(c7.conversions_7d, 0) * 100, 1) as lift_from_longer_window
FROM spend_by_window s
LEFT JOIN conversions_7day c7 ON s.channel = c7.channel AND s.campaign_id = c7.campaign_id
LEFT JOIN conversions_30day c30 ON s.channel = c30.channel AND s.campaign_id = c30.campaign_id
ORDER BY cpa_30day ASC;CPA Trend Analysis
-- Track CPA trends over time
WITH weekly_metrics AS (
  SELECT 
    DATE_TRUNC('week', spend_date) as week,
    channel,
    SUM(cost) as weekly_spend
  FROM marketing_costs
  WHERE spend_date >= CURRENT_DATE - INTERVAL '12 weeks'
  GROUP BY 1, 2
),
weekly_conversions AS (
  SELECT 
    DATE_TRUNC('week', conversion_date) as week,
    acquisition_channel as channel,
    COUNT(*) as weekly_conversions
  FROM customers
  WHERE conversion_date >= CURRENT_DATE - INTERVAL '12 weeks'
  GROUP BY 1, 2
)
SELECT 
  m.week,
  m.channel,
  m.weekly_spend,
  COALESCE(c.weekly_conversions, 0) as conversions,
  ROUND(m.weekly_spend / NULLIF(c.weekly_conversions, 0), 2) as weekly_cpa,
  AVG(m.weekly_spend / NULLIF(c.weekly_conversions, 0)) OVER (
    PARTITION BY m.channel 
    ORDER BY m.week 
    ROWS BETWEEN 3 PRECEDING AND CURRENT ROW
  ) as cpa_4week_avg,
  LAG(ROUND(m.weekly_spend / NULLIF(c.weekly_conversions, 0), 2)) OVER (
    PARTITION BY m.channel 
    ORDER BY m.week
  ) as prev_week_cpa
FROM weekly_metrics m
LEFT JOIN weekly_conversions c ON m.week = c.week AND m.channel = c.channel
ORDER BY m.week DESC, m.channel;Attribution Considerations
Use consistent attribution models (first-touch, last-touch, or multi-touch) and appropriate time windows. Account for view-through conversions and offline influences.
Best Practices
1. Cost Attribution
- Include all marketing costs (ad spend, creative, management fees)
- Use consistent attribution models across channels
- Account for organic uplift from paid campaigns
- Consider overhead and operational costs
2. Time Window Selection
- Align attribution windows with typical customer journey length
- Use 7-day windows for quick-decision products
- Use 30-90 day windows for considered purchases
- Monitor conversion lag patterns by channel
3. Channel Optimization
- Compare CPA against customer lifetime value
- Consider quality and retention differences by channel
- Test different creative and targeting approaches
- Account for scale limitations of low-CPA channels
4. Benchmarking
- Set target CPA based on unit economics
- Benchmark against industry standards
- Track CPA trends over time
- Monitor competitive landscape impact
5. Optimization Strategies
- Audience Targeting: Refine targeting to reach higher-intent users
- Creative Testing: Test ad creative and landing pages
- Bid Management: Optimize bidding strategies and budget allocation
- Conversion Optimization: Improve landing page and funnel conversion rates