DocsFeaturesAdvanced

Advanced

Query Builder Features

Session Metric Analysis

/Screen_Shot_2022-07-11_at_3.53.47_PM.png

Analyze session metrics by selecting “Session Start” or “Session End” from the events list. Learn more about using Sessions in Insights, Funnels, and Flows here.

Inline Filtering

Filter this event by clicking the inline action menu and selecting Add filter from the drop-down. Choose an event property, user profile property, group profile property, or cohort to filter the event by.

image

You can select whether you would like your query to match any or all of the filters by clicking on and/or beside the filters.

image

Duplicating Events

To duplicate any events or properties in your query, select the inline action menu and choose Duplicate. Delete any events or properties by clicking the trash icon.

image

Advanced Date and Time Selectors

You can also choose how Mixpanel buckets the time range in Insights, Funnel Trends and Retention Trend reports (granularity may vary). To view a range in hours, you can select Hour as the view:

image

To zoom in, click on the graph and drag to highlight a specific window of time in your report. Click Reset zoom to return to the previous view.

zoom (1)

Advanced Filter & Breakdown Usage

To filter the results of your report by any property or cohort, click the Filter button.

To break down the results of your report by any property or cohort, click the Breakdown.

You can break down your results by the “Time” event property and break down by Hour, Day, Week, Month, Quarter, Year, Hour of Day, or Day of Week.

/breakdown_by_date.gif

If you are analyzing any custom events, you can break them down by the property “Event Name”.

image

The drop-down menus only show events/event properties that were ingested within the last 30 days. To select events/event properties that have not been ingested in the last 30 days, type the name of the event/event property in the Filter or Breakdown search bar. You must know the exact name of the event/event property you want to select because event names are case-sensitive.

/query_old_event.gif

To create a temporary cohort for the current report, click Create Custom… in the dropdown menu and select “Cohort. A window will pop up where you can specify the restrictions of your cohort. Learn more about building a cohort here.

/create_cohort_from_report.gif

Slack Integration

Connect Mixpanel to your Slack workspace to help share reports with your colleagues faster. You can (1) set up an alert to send a message to a Slack channel, (2) set up a Board Subscription to send a message to a Slack channel, or (3) share previews of any Mixpanel report in Slack.

To send an alert to a Slack Channel, see Custom Alerts. To set up a board subscription to a Slack Channel, see Advanced Board Functionality - Subscriptions.

The Mixpanel application for Slack will also automatically unfurl a preview of any Mixpanel link, including chart images for certain reports, making it easy for anyone in your Slack workspace to learn from your Mixpanel analyses.

Enable the Integration

To enable the integration, log in to both Mixpanel and Slack, then click here to authorize the Slack workspace:

/Screen_Shot_2020-06-15_at_10.41.00_PM.png

After clicking allow, you’ll return to Mixpanel, where you’ll see a success banner:

/Screen_Shot_2020-06-15_at_10.42.06_PM.png

At this point, Mixpanel is a part of your Slack workspace, and any Mixpanel links you send in Slack will unfurl with metadata, and if applicable a chart preview.

Once at least one member of your Mixpanel organization has set up the Mixpanel Integration for Slack for their account, any other members of the Slack workspace will see a prompt the next time they paste a Mixpanel link. The prompt will ask them to connect their own Mixpanel account to Slack as well. If they choose to do so, Slack will guide them through the authentication flow. Once they have successfully connected Mixpanel to Slack, any further links they paste in Slack will unfurl.

Using the Integration

Once you’ve set up the integration, Mixpanel links pasted in Slack will unfurl. Most links will provide some basic link metadata, and links to Insights, Flows, Funnels, or Retention reports will also include a chart preview, for example:

/slack_app_demo.png

Permissions

Mixpanel does not restrict who can enable the Mixpanel integration for Slack. However, your Slack workspace may limit who can perform the connection.

After Mixpanel is connected to Slack, any Slack user who posts a Mixpanel link will be prompted to connect their own account to unfurl report previews. Performing this integration at the user level ensures that only reports the user has access to will unfurl in Slack.

Privacy

The Mixpanel app for Slack adheres to Mixpanel’s overall privacy policy, available in full here: https://mixpanel.com/legal/privacy-policy/.

Custom Buckets

Custom buckets let you group existing properties into meaningful segments on the fly. This is focused on enabling every person to answer common segmentation questions easily, quickly, and in a low-friction way.

Example use-cases include:

  • Compare how the core markets are performing between US vs UK vs China vs all others
  • Compare how many sign-ups are brought in by organic search vs Google ads vs social media channels together (Facebook, Twitter, LinkedIn)
  • Compare # videos watched for users between ages 18-30 vs 30-40 or 40+
  • Compare # users based on duration of video watched: < 30, 30-60, 60-90 mins

Creating Custom Buckets

Add a property in Breakdown, then select the Customize Buckets option from the overflow menu

/14342458665748

Depending on your added property data type - string vs numeric, you will see a different custom buckets modal, designed based on the data-type use-cases (more detail below)

Once you define your segment buckets, click Apply. Only then will the custom buckets reflect in the visualization. You will also see the custom buckets as an under-item on the property

/14342458667924

To modify the segment buckets, click on the under-item and the custom buckets model will open. Once you’ve made the changes, click Apply

To remove all grouping and revert to the default, open the custom buckets modal and click Reset

Note that you cannot have more than 10 uneven (varied) groups.

String property Use Cases

Use Case: You want to compare # videos watched between core markets - North America, Europe & China

Current: You have a property “Country”

Goal: You want to group the countries into meaningful segments

  • Segment 1: North America: US & Canada
  • Segment 2: Europe: UK, Germany, France, Netherlands, Italy
  • Segment 3: China
  • Segment 4: Rest of the World (everything but those above)

Steps

  1. Add a breakdown - Country. Below is the default you’ll see

    /12828869626644

  2. Choose to bucket segments, by opening the custom buckets model and clicking Apply

    • For each segment, choose the operator “is” and select one or more values
    • “Rest of the World” is auto-generated as remaining values
    • To note — if two segments have the same value, the first segment will consider the value. Custom buckets are non-overlapping and sum up to 100% by definition

/14342715436052

/12828860042132

You can also re-name these segments to make them meaningful to you

  1. On the same line of the segment, choose to rename it using the pencil icon
  2. Click Apply after creating and naming your segments as desired

/14342752741140

/12828869956628

Numeric property Use Cases

Use Case: You want to compare #users based on duration of video watched

Current: You have a property “watch time (mins)”

Goal: You want to distribute this in various ways

  • Use Case A: Evenly in 10 min groups for the range 50-100 mins
  • Use Case B: Specific groups <10, 10-20, 20-50, 50-100, ≥100
  • Use Case C: Want to see all the durations as-is (No grouping)

Deep Dive: Use Case A: Evenly in 10 min buckets for the range 50-100 mins

  1. Add a breakdown - “watch time (mins)”

    • To note — every numeric property is auto-bucketed into even-sized buckets as the default

    • Here the default seems to be even buckets of 10 mins across the range

      /14342489051028

      /12828860268692

  2. Go to the overflow and open the custom buckets modal

  3. Since looking for even buckets of “30 mins”, choose Even Bucketing

  4. Modify the min and max values of the desired range, and the bucket size, and click apply

    • To note — both a lower-end and upper-end bucket will be auto-generated to ensure your breakdown always adds up to 100%

    • Here these buckets are <50 mins and ≥ 100 mins

      /14342575096724

      /12828860573204

Deep Dive: Use Case B: Specific groups <10, 10-20, 20-50, 50-100, ≥100

  1. Open the custom buckets modal
  2. Since looking for specific buckets with varied bucket ranges, choose Varied Bucketing
  3. Enter the ‘segment’ breakpoint values in each row and click apply. You can preview the bucket as you enter values in the line item below
    • To note — both a lower-end and upper-end bucket will be auto-generated to ensure your buckets always add up to a 100%

/14342546138516

/12828860758676

Deep Dive: Use Case C: Want to see all the durations as-is (No bucketing)

  1. Open the custom buckets modal
  2. Since looking for “No bucketing”, choose None — This lays out all the numeric property values as-is

/14342547991956

/12833587659028

Typecasting property Use Cases

Use Case: You want to identify #users of age 18 and age 60 since these are user ages where they change subscription plans (upgrade and downgrade respectively)

Current: You have a property age (years)

Goal: You want to group this in a meaningful way

  • Segment 1: Age 18 (potential to upgrade)
  • Segment 2: Age 60 (potential to downgrade)
  • Segment 3: Every other age

Steps

  1. Add a breakdown age(years). By default, this will add as a numeric property

  2. Since you are looking for pin-pointed years and not creating number ranges, this is a question more common to string property data type

  3. Change Data Type of age(years) to String. Once changed you will see the type-casted property type as an under-item

    • To note - only type-casted data types show as an under-item. If the data type was the same as ingested, no under-item for data type will be seen

      /14342634016660

      /12833644608148

  4. Post changing data type, open the custom buckets modal. This will now open a modal meant for string property data type

  5. Follow the steps as elaborated for the String property use-case above, and achieve the goal

    /14342637801748

    /14342707763604

    /12833899595284

FAQ

  • Which reports does Custom Buckets work on?

    This feature is available in the Insights, Funnels, and Retention reports.

  • Which property types does this support?

    Custom Buckets work on String, Numeric, and List data type

  • Can I save a Custom Bucket?

    No, you can’t save a custom bucket. If your custom bucket is something you or your team would like to re-use, we encourage you to instead create a custom property.

  • How is custom buckets different from custom property?

    Custom buckets only support the most common custom-property use-case of if else to create meaningful segments in a more simplistic UI and a low-lift way to enable quick ad-hoc exploration. You could get this same answer using custom property too, it would just be more effort and not as intuitive

  • Can I create over-lapping segments like (US & UK) vs (US & Australia)?

    No, breakdowns are fundamentally designed to sum up to 100%. To ensure your analysis is accurate, please create non-overlapping segments.

    If you really need to answer a question like this, the right way here is to create these as two metrics leveraging inline filters and NOT use breakdowns.

    /12834111393684

  • What happens if I change the data type, can I still use custom buckets?

    Yes, as long as the data type you’ve changed the property to is supported.

  • Understanding the details:

    • In Numeric: Can I change the operators on the upper and lower bound?

      No, the operators have been fixed. The lower bound is always strictly greater than (≥) and the upper bound is just lesser than (<). If you are looking for more control over the operators, please create a custom property.

    • In String: Is (not set) included in (remaining values)?

      No, (not set) is not included in the remaining values

      • (remaining values): refers to ‘set’ values that just don’t fall into any of your defined segments
      • (not set) refers to the events where a property value has not been set at tracking/ ingestion. For example, a new video (MixFun) has been added, but during tracking, you forget to send the name of this video. So the count of this video is being tracked, but it’s being associated with a property value (not set) vs (MixFun)

      More details can be found in this help doc

    • In Numeric: What is the difference between (not set) and (non-numeric values)?

      • (not set) as explained above for string refers to property values that have not been associated with any specific property value
      • (non-numeric values) refers to set values that have just been sent in as non-numeric data type. For example, you’re looking to track time spent and have coded that as a numeric property, but for some reason some values are tracked as “a”, or “b” which are not numeric.
  • Some Common How-do-I(s)

    • How do I know is set, (not set)?

      (not set) is automatically computed and will always show up in the UI. You don’t have to select (not set) as a segment to know how many events fall in there. So only figure how would you like to segment your (set) values.

      /12834113971348

    • How do I get “not contains” or “not equal to”?

      These values will auto-generate under (remaining values). So just select what should be included

      For example — the (remaining values) below is not equal to US or India

      /12834082079380

    • In Number: how do I get a bucket of just 0?

      If you’re purely looking for just how many people have value “0”, we would encourage you to typecast this to a string property and get that.

      If you’re looking to get the count of 0, in reference to the other numeric buckets, go ahead and create a Varied Bucketing custom buckets modal

      • If the numeric values are integers:
        • Choose Varied bucket values 0, 1, 2…
        • This would generate buckets: <0, ≥0 & <1, ≥1 & <2, ≥2.
        • ≥0 & <1 would be equal to bucket 0
      • If the numeric values are decimals:
        • Choose Varied bucket values 0, 0.0001, 1, …
        • This would generate buckets: <0, ≥0 & <0.0001, ≥0.0001 & <1, ≥1.
        • ≥0 & <0.0001 would approximate to bucket 0

View Users

View Users is a streamlined process for exploring the users contributing to a specific metric or point on a chart. By interacting with the chart, you can view a group of users experiencing friction or dig deep into which users are driving feature adoption.

View Users can help you:

  • See the users contributing to any metric and view their recent activities & properties.
  • Save these users as a cohort.
  • Export these users to a CSV file.

Insights

/View_Users_Insights_gif.gif

  • To learn more about your users who recently Signed Up at a specific point in time, you can click any point on a chart or line to access View Users. The View Users overlay displays the list of users contributing to your chosen point on the chart.
  • By clicking on one of these users, you can further explore their User Properties like experiment group, purchase count, last event, and many more.
  • While viewing a specific user, you can also discover their recent activities (*Like, Comment, Message Sent, Ad Conversion,* etc) after Sign Up through the Activities menu.

Funnels

/View_Users_Funnels_gif.gif

  • Finding the exact group of users who dropped off after Sign Up is possible through View Users in Funnels. While in a Funnels report, click on the section of the chart that displays non-converting users and select View Users - this displays the list of those who didn’t convert after signup.
  • Save this group as a cohort by clicking the Create Cohort button. Now, you can learn more about their product usage or find the root cause of why they didn’t convert after Sign Up.

Retention

/View_Users_Retention_gif.gif

  • View Users in Retention report presents you with two options - view retained users and view dropped-off users. This is helpful to find the specific group of users who were engaged or dropped off after Sign Up over a period of time.
  • Export your group of choice to a CSV with one click. This data can guide meaningful actions, like emailing your user group a note that helps them get unstuck and engaged.

Keyboard Shortcuts

Undo / Redo Shortcuts

Undo / redo shortcuts allow for fast adjustments to your analysis. Cmd + Z to undo; Cmd + Shift + Z to redo. Change filters, date ranges, line vs bar chart, and go back in one second to compare before and after, or fix the view.

/Undo_Redo_gif.gif

  • Navigate different report versions: add a new event, filter, or breakdown and undo that change with Cmd + Z. This makes iterating between different versions of your report quick and easy.
  • Compare visualizations: go from a bar chart to a line chart, to a pie chart, and all the way back, while only using the undo / redo keyboard shortcuts.

Comparison: Time, Baseline and Overall

Once you have visualized a metric you are interested in, you want to compare it against related metrics to gain further insight. Previously, only comparing against past values was supported, but there are now 3 different ways to compare your metrics. The ability to do and show comparisons across segments is also supported in Boards, so any report saved will also reflect in Boards.

Time Comparisons

/Screen_Shot_2021-09-22_at_4.38.05_PM.png

The compare-to-past menu has been modified to include the new comparison options, but users can continue to find the same-time comparison options that existed before under the new “Compare” menu.

Time Comparison - Absolute Values

/Screen_Shot_2021-09-22_at_4.40.26_PM.png

This is the same default behavior that existed previously. When you compare to a time period users will see a solid line for the present data, and a dashed line for data in the time comparison period.

Time Comparison - Percentage change over Baseline

This can be activated by selecting the “Percent change over Baseline” option in the controller next to the comparison menu.

/Screen_Shot_2021-09-22_at_4.40.41_PM.png

When this view is activated, users will see the percentage difference from one time period to another. This is the same value that was shown in the tooltip, but now users are able to show how segments are shrinking and growing over time. This also makes it easier to see relative performance between different segments.

/Screen_Shot_2021-09-22_at_4.50.52_PM.png

These values are also reflected in the segmentation table below the chart.

Increase over Baseline

Another comparison type that is now natively supported in Mixpanel is the ability to set a segment as a baseline from which other segments are compared against. This allows users to compare different segments across the same time period.

/Screen_Shot_2021-09-22_at_4.50.28_PM.png

/Screen_Shot_2021-09-22_at_4.50.36_PM.png

To enable, choose the “Increase over Baseline” option in the compare menu, then choose the segment that you wish to be the baseline.

/Screen_Shot_2021-09-22_at_4.53.21_PM.png

Notice that because “Home supplies” is chosen at the baseline, it appears on the chart as a flat 0 line - this is because “Home supplies” always has a 0% difference against itself in the same time period.

Also note that the y-axis can go below 0, because segments can perform better or worse than the selected baseline, like “Entertainment” above.

Percentage of Overall

This option allows users to see how segments perform as a percentage of the total. Mixpanel will proactively disable this option when this comparison option won’t give meaningful results.

/Screen_Shot_2021-09-22_at_5.10.53_PM.png

To enable, open the Compare menu and select “Percentage of Overall”

/Screen_Shot_2021-09-22_at_5.17.27_PM.png

Why do the values in Compare to Overall not add up to 100%?

Depending on the type of metric, the percentages may not add up to 100%. This is because the value is being compared to the unsegmented value. For example, if you were you segment Total “Add Item to Cart” events by “Category”, then the values should sum up to 100% since an item might not be a part of different categories.

However, if the metric was “average price”, then the average price across all categories might be $10. Within individual categories, the average price might be lower or higher, and that is the comparison being done by “Compare to Overall”. In this case, the percentage values would not add up to 100%.

More generally, if the metric is summable, and the groups are mutually exclusive, then the percentages will add up to 100%. if the metric is a non-counting metric like uniques or percentile aggregation, the percentages will not add up to 100%. Another example is if the breakdown is by cohorts, where users can be members of multiple cohorts, the percentages will not sum to 100%.

Supported Charts

Comparisons are supported across all insights chart types. Depending on the exact configuration chosen, certain comparison operations may be disabled.

Chart TypeTime Comparison SupportedPercentage change over Baseline SupportedPercentage of Overall Supported
Insights LineYesYesYes
Insights Stacked LineNoNoYes
Insights BarYesYesYes
Insights Stacked BarYesNoNo
Insights PieNoNoYes
Insights MetricYesYesYes
Funnels StepsYesYesNo
Funnel TrendsYesYesNo
Retention CurveNoYesNo
Retention TrendsYesYesNo

Limits and Ordering

Summary

In order to keep the interactive analysis experience snappy for projects of all sizes, we’ve made 2 changes:

  • Added maximum limits to how many segments are returned when breaking down a metric by properties
  • Changed the logic for the top segments that are returned

Limits

UI

We’re changing how many segments are returned back to the report (visible limit), how many segments can be selected at a time for visualization (selection limit) as well as the number of segments selected by default (default selection).

Here’s the breakdown per report + visualization type:

Report VizDefault SelectionSelection LimitVisible Limit
Insights (bar)123003000
Insights (line)12503000
Retention612200
Funnels612200

Downloaded CSV and API

When downloading results as CSV or when querying our APIs, the limits remain unchanged.

Top Segments logic

The way we pick the top segments differs according to the type of query. We choose the top segments based on the value shown in the second column.

Query typeHow we select top segments
TotalTotal number of occurrences of the chosen event
UniqueNumber of unique users who performed the chosen event
Sum of property valuesSum of the chosen property
Min/max of property valuesLowest/highest value of the chosen property
AverageNumber of events (or users) that contribute to the average
Median/Percentile/DistributionNumber of events (or users) that contribute to the distribution
Distinct countNumber of distinct values of the chosen property
DAU/WAU/MAUNumber of unique users
SessionsNumber of sessions that contain the chosen event
FunnelsTotal number of times the first funnel step was completed
RetentionTotal number of times the first event was completed

FAQ

How will I know if my results are being pruned?

You will see an indication like this:

image

Does this mean the downloaded CSV has lower limits?

No, limits for CSV downloads remain unchanged across Insights, Funnels, and Retention.

Analyzing First Time Users

Sometimes, you might want to filter an event to only the first time that it’s performed by a user. This helps answer the following questions:

  • How many users sign up or perform another key event for the first time each week?
  • Which referrers do most first-time users come from?
  • How quickly do users make a purchase after their first time engaging with the app?
  • How well do users retain after performing a key event for the first time?
  • What events do users perform before and after making their first purchase?

You can do this by adding a First Time Filter to any event in Mixpanel. This filters the event down to only the first instance of the event performed by a user:

233894752-93851682-9d83-4c87-937d-8fd90db465c6.png

Mixpanel computes this on-the-fly by scanning each user’s history to determine if this was the first instance of the event performed by the user, based on timestamp. Note that when there’s a tie in the timestamps of the first event (eg: the user does multiple first-time Purchases in the same second), all of those events will be considered the “first time” and will match the filter. The impact will be that Mixpanel includes multiple events for those users, so if you break down by user ID, you may see that the user did multiple first events.

Nth Time

You can analyze the Nth time an event was performed by using a First Time Filter in funnels. For example, this shows you the number of users that do Tutorial Complete 3 times:

233895123-bc2dd00f-5dde-4e43-82fe-081173abf0e4.png

Behavioral Properties

Behavioral properties allow you to use your user’s activity and use it as a property in your other analysis. A behavioral property is a virtual property, meaning it’s not a property that you are explicitly tracking, but a property that Mixpanel can compute and allow you to use in analysis.

Behavioral properties can be used anywhere, most typically in filters and breakdowns.

Frequency per User

After selecting this option, you must select an event to compute the frequency of. You can use this to segment your users by how many times they did an event, or use it to filter out users to only those who did an event a certain number of times.

Aggregate Property per User

After selecting this option, you must select an event, and then a property on that event. Finally, you can choose an aggregation type for this property. You can use this to segment your users by this property aggregation. For example, you may want to filter only for users who have greater than 100 minutes of video watch time, or you may want to segment users by their watch time.

Time Range

Per Interval

In insights, the time in which this computation is done is on a per-interval basis. For a line chart, that will be for each individual interval plotted on the chart. For bar, table, and pie, this interval is the entire date range selected in the date picker.

Between Steps

In funnels, the behavioral property is computed in the time range between 2 steps in your funnel. You can specify which steps in the funnel this applies to. In the case of doing “Frequency per User”, the event count does not include the events that make up the funnel itself, and only the events between the funnel steps.

After Step 1

In retention, the behavioral property is computed in the chosen time range after the entry event, up until the expiration window. For example, there may be a 7-day window in which we’re looking for an event. Even if the retaining action happens before the 7 days are up, we continue to count additional events.

Find Interesting Segments

Determine which users are either driving conversion and retention or behaving as outliers by using the built-in “Find Interesting Segments” feature.

Find Interesting Segments can help you discover:

  • Whether certain property segments outperform the overall funnel conversion or retention rates.
  • Which cohorts perform the best to get ideas on optimizing cohort behavior.
  • Which segments are under-performing.
  • Changes in the conversion or retention rates of segments.
  • Change in population over time in funnels.

User properties are not yet supported.

Interesting Segments in Funnels

View the top and bottom converting segments in your funnel by clicking the Find interesting segments button at the bottom of the segmentation chart.

/10038188905364

Rather than searching through multiple property breakdowns to find significant data, this feature automatically identifies this data for you. Mixpanel combs through your event properties and cohorts to show you which of those segments convert higher or lower than average, and are therefore statistically significant.

There are two reports you will receive in your email: segment analysis and time comparison.

Segment Analysis

An email that breaks down the top and bottom converting segments of your funnel based on statistical significance and other factors is automatically sent after you click the button. If no statistically significant segments are found, then the email shows non-statistically significant segments.

Segment Analysis helps answer questions such as:

  • Which groups of users are driving my conversion rate?
  • Which groups of users are decreasing my conversion rate?

This is done by examining which segments of users are converting at a high rate and have a large enough population size, or which segments are converting at a low rate and have a large enough population size. In the first scenario, this segment would raise the overall conversion rate, while in the second scenario, this segment would be lowering the overall conversion rate.

Time Comparison

A time comparison chart is also included in the email. This chart shows a segment’s behavior over time (in terms of both conversion rate change and population size change) as it relates to the overall population trend (population and conversion rate change).

Time comparison answers questions such as:

  • Which groups of users are trending in a way that is different from the overall behavior?
  • Which groups of users are driving the overall behavior?

Mixpanel automatically compares the currently selected date period to the previous one. For example, if you are viewing the current week, the email will compare to the week before.

Interesting Segments in Retention

View the top and bottom converting segments in your retention report by clicking the Find interesting segments button at the bottom of the retention chart. This feature is not currently available for Frequency Retention.

/10037069627156

Rather than searching through multiple segment breakdowns to find significant data, this feature automatically identifies that data for you. Mixpanel combs through your event properties and cohorts and shows you which of those segments retain at a higher or lower rate than average.

An email that breaks down the top and bottom retaining segments of your Retention report based on changes in retention rates is automatically sent after you click the button.

Interpret Email Results

When your analysis email says “no interesting segments”, this means that none of the segments you analyzed were behaving significantly differently from the overall population at a large enough volume. To resolve this issue, try extending the date range of the report or try a different report.

If the analysis request included dates in the past five days and is sent from mobile SDK, data may be delayed and therefore not included at the time of the analysis. Likewise, the date window selected might still fall under the conversion window, and more conversions have yet to come through.

Results are sorted by taking into consideration the property, the number of users in the report, as well as the deviation from overall conversion or retention behavior to surface the most meaningful segments to you.

Query Time Sampling

Query-time sampling allows you to query a subset of users and shorten the time it takes for a report to load results. The Insights, Funnels, Retention, and Flows reports all support sampling at query time.

This feature is available to enterprise customers with over 5 million MTUs or over 2 billion monthly events.

Enable or Disable Query Time Sampling

Navigate to the report where you would like to enable or disable sampling at the time of the query.

Enable Sampling

From the report in which you would like to use sampling, click the lightning bolt in the upper right corner of the query builder.

/13109650264596

This will enable sampling on the report and will be indicated by the lightning bolt symbol turning blue. The percentage of the total that is included in the query calculations will be indicated in the top right corner of the query builder.

Disable Sampling

To turn off sampling, click the lightning bolt symbol in the upper right corner of the query builder again.

The lightning bolt symbol will turn grey to indicate that sampling is disabled.

Query Time Sampling Calculation and Presentation

Mixpanel will not sample, or drop, events at ingestion. Instead, Mixpanel will ingest all event data and sample it at query time. This prevents the loss of important data and, therefore, allows you to toggle sampling on and off depending on need.

For example, if you have a need for iterative querying, then sampling will greatly speed up this process. When you build the proper query, you can turn off sampling and query the entire dataset.

The following occurs when sampling is enabled:

  1. Mixpanel selects a uniformly random sample of users on which to run the analysis.
  2. The sample size is 10% of the total population.
  3. The report is generated using that subset of users.
  4. Mixpanel up-samples the data by multiplying by the inverse of the sampling factor. This is done for functions such as totals and uniques. Functions that do not scale with users (average, min, max) will not be up-sampled.
  5. The effect is that numbers should closely approximate results seen without sampling enabled. This works better as the number of users increases, particularly for customers with more than 5 million users.
  6. Mixpanel adds an annotation to reports.

Saved Reports with Query Time Sampling

If you save a report that uses query time sampling, then a version of the report without sampling is saved. This ensures that Boards and saved reports are computed on the entire dataset for high fidelity.

Query Result Caching

Mixpanel stores the results from a report query in our server cache and presents these results from there when appropriate. This saves time when running a complicated query multiple times, and allows you to surface previously calculated results near-instantaneously. The date range of the query will adjust how Mixpanel presents results from the server cache.

  • If the query date range is 1 year or over, then the query results are cached for up to 14 days.
  • If the query date range is under 1 year, then the query results are cached for up to 7 days.
  • If the query date range is under 6 months, then the query results are cached for up to 3 days.
  • If the query date range is under 2 months, then the query results are cached for up to 2 days.
  • If the query date range is under 1 month, then the query results are cached for up to 1 day.
  • If the query date range is under 1 week, then the query results are cached for up to 12 hours.
  • If the query date range is under 1 day, then the query results are cached for up to 1 hour.

While this highlights the default server cache behavior, you can always refresh a report to include the most current data as described below.

Refreshing the Query Results Cache

To refresh the query results cache, navigate to the report, click the three dots overflow menu at the top of the report, select Refresh Data.

public/Refresh_Data_Report.png

To refresh the query results’ cache in a Board, click the three dots overflow menu at the top of the Board, and select Refresh Data.

public/Refresh_Data_Board.png

To refresh the query results’ cache in a Board card, click the three dots overflow menu at the top of the card, and select Refresh Data.

public/Refresh_Data_Board_Card.png

Event and Property Limitations

While all reports in Mixpanel utilize your event data and properties to deliver insight into your business, not all reports can use all event types or properties.

Reports use events and properties to target users, segment data, and filter data. This guide will clarify which reports can use which event types and properties.

Insights: All event types and properties are available in Insights to break down and filter data.

Funnels: Funnels can be calculated by unique or total events. All event types and properties are available to break down and filter data.

Retention: Retention only counts total users, not unique. However, all event types and properties are available to filter data.

Signal: Signal uses only event properties, not user profile properties. However, all event types are available to filter data.

Users: All event types and properties are available in Users.

Downloading Reports from Mixpanel

Users can download reports in three formats:

  • CSV
  • PNG
  • PDF

Breakdown Limits in Report Downloads

Mixpanel maintains breakdown limits for CSV, PNG, and PDF report downloads.

CSV

For property values that exceed 10,000, Mixpanel only returns the top 10,000 breakdowns of that property. Here’s an example CSV export of an Insights report. The first column contains the date of when each event was sent. The columns contain the event name and the rows contain the number of each event sent to Mixpanel.

/CSV-download.png

PNG and PDF

PNG and PDF downloads display up to 30 segments in the Insights table, Insights bar, Retention table, and Retention line; and up to 12 segments for the Insights line. Here’s an example of a chart in PNG format.

/PNG-example.png

Downloading Reports

To download Insights, Funnels, and Retention reports, click the ”…” icon on the upper right corner of each report.

Insights Download Menu

image

Funnels Download Menu

image

It is possible (only in the Funnels report) to download “CSV Trends”, which downloads funnels by date.

Retention Download Menu

image

Was this page useful?