All tutorials
No items found.

Build a data ingestion pipeline from Stripe to Snowflake

Extract data from Stripe’s REST API and send it into Snowflake.

Millions of businesses use Stripe APIs to accept payments, send payouts, and manage their online transactions. Nevertheless, Stripe’s analytical capabilities are limited, offering only a small set of metrics such as gross volumes, net sales, new customers, successful payments, and so on.

To improve your Stripe analytics capabilities, you can use Stripe’s REST APIs to extract your Stripe transactions and replicate your Stripe data into a modern data warehouse architecture such as Snowflake. Snowflake is purpose-built for online analytical processing (OLAP), and once your data is in Snowflake tables it can be easily combined with data from other internal systems, which will provide you with enhanced insights into your business.

One challenge that you may come across is that extracting your Stripe data may require skilled Stripe developers and extensive consultations to Stripe's developer documentation. Furthermore, once you get the data out of Stripe, that is only half the battle – you still need to drive your data into Snowflake! Luckily Airbyte makes this easy by providing a Stripe source connector and a Snowflake destination connector. Airbyte data connectors make it easy to build a data pipeline to move your Stripe data to Snowflake without the need for extensive consultations to the Stripe developer portal or to Stripe’s developer docs.


  1. Register for Airbyte Cloud or deploy Airbyte Open-Source.  This tutorial is presented using Airbyte Cloud, but most of it should also work with the Open-Source version of Airbyte.
  2. An active Stripe and Snowflake account.

Step 1: Set up your Stripe account

You will need an active Stripe account to follow this tutorial. Airbyte requires your Stripe Account ID and Secret Key. You can find the Account ID by visiting  your account settings.

To find the Secret key, visit the API keys page. You can find more about managing API keys in Stripe developer documentation.

Step 2: Set up your Snowflake account

If you don’t already have a Snowflake account, you’ll need to pick a Snowflake edition and a cloud provider for your warehouse as part of the account creation process.

The Snowflake dashboard will appear after you create a username and password. The worksheet area will be where you’ll run scripts and SQL queries for creating, visualizing, and modifying resources.

For Airbyte to successfully sync data from Stripe, you need to create a data warehouse and a database. Luckily, Airbyte provides a nice ready-to-execute script that lets you do it in a few seconds. You can read more about setting up a Snowflake destination in Airbyte’s Snowflake docs.

The main steps in the following script are:

  1. Setting Airbyte variables to be used later in the script. Make sure to change the default values in the script according to your preferences. Also, make sure to use a secure password.
  2. Create a new sysadmin role
  3. Create a new user, AIRBYTE_USER, and grant them privileges
  4. Set up a warehouse AIRBYTE_WAREHOUSE.
  5. Create a database named AIRBYTE_DATABASE inside this warehouse

-- set variables (these need to be uppercase)
set airbyte_role = 'AIRBYTE_ROLE';
set airbyte_username = 'AIRBYTE_USER';
set airbyte_warehouse = 'AIRBYTE_WAREHOUSE';
set airbyte_database = 'AIRBYTE_DATABASE';
set airbyte_schema = 'AIRBYTE_SCHEMA';

-- set user password
set airbyte_password = 'password';


-- create Airbyte role
use role securityadmin;
create role if not exists identifier($airbyte_role);
grant role identifier($airbyte_role) to role SYSADMIN;

-- create Airbyte user
create user if not exists identifier($airbyte_username)
password = $airbyte_password
default_role = $airbyte_role
default_warehouse = $airbyte_warehouse;

grant role identifier($airbyte_role) to user identifier($airbyte_username);

-- change role to sysadmin for warehouse / database steps
use role sysadmin;

-- create Airbyte warehouse
create warehouse if not exists identifier($airbyte_warehouse)
warehouse_size = xsmall
warehouse_type = standard
auto_suspend = 60
auto_resume = true

initially_suspended = true;

-- create Airbyte database
create database if not exists identifier($airbyte_database);

-- grant Airbyte warehouse access
grant USAGE
on warehouse identifier($airbyte_warehouse)
to role identifier($airbyte_role);

-- grant Airbyte database access
on database identifier($airbyte_database)
to role identifier($airbyte_role);



USE DATABASE identifier($airbyte_database);

-- create schema for Airbyte data
CREATE SCHEMA IF NOT EXISTS identifier($airbyte_schema);



-- grant Airbyte schema access
on schema identifier($airbyte_schema)
to role identifier($airbyte_role);


You can copy and run this whole script in a new Snowflake worksheet. Make sure to select “All Queries” when executing the worksheet. 

ℹ️  Note that you should rename all the values for database, warehouse, roles, and user variables in the Snowflake setup script.  For simplicity and testing purposes, you will be using default values. This example also uses the sysadmin role, and you should assign reduced permissions to the service account before deploying in production.

After you run the script, Snowflake will tell you whether the command was successfully executed. You can visit the warehouse section to confirm that there is a new warehouse with the name AIRBYTE_WAREHOUSE and the configuration that you defined in the script.

Now that you have configured Snowflake, you are ready to create an ELT pipeline from your Stripe source to your Snowflake destination.

Step 3: Set up Stripe as an Airbyte source

The Airbyte Stripe source connector can be used to sync the many different tables from your Stripe account.  Some examples of available Stripe tables are:

  1. Balance Transactions
  2. Bank Accounts
  3. Invoice
  4. Customers
  5. Charges
  6. Subscriptions

You will define a Stripe source which will be used by Airbyte to extract data from the Stripe REST API. Go to sources and create a new Stripe source from the dropdown.

You can choose whatever name you like for the Stripe source.  Use the Account ID and Secret Key that you found earlier in this tutorial. The replication date should be set to a date from before your Stripe account became operational. 

Step 4: Set up Snowflake as your Airbyte destination

Go to the destinations tab in your Airbyte cloud dashboard and select Snowflake as a new destination.

You will need the following details:

  1. The Snowflake host, which is the Snowflake account identifier (E.g.,
  2. The role to be used for accessing the Snowflake warehouse/database
  3. Warehouse, which is the warehouse identifier 
  4. The database name
  5. The schema name
  6. A username, which you created previously while setting up Snowflake
  7. The password of the above user.

Enter the data as follows:

For the purposes of this tutorial, do not set JDBC URL Params

ℹ️  JDBC URL Params is an optional property may be used to pass custom key-value pairs for connecting to Snowflake.

The Data Staging Method defines where the data is stored (or staged) so that Snowflake can efficiently load it into tables. By default, Airbyte uses Snowflake’s Internal Stage to load data. You can also choose to load data from Amazon S3 or any other cloud host. You can read more about setting up a data loading method in Airbyte’s docs.

Create the destination. This may take a few seconds until Airbyte authentication takes place.

Step 5: Set up a Stripe to Snowflake Airbyte connection

The final step to create a Stripe data pipeline to Snowflake involves creating the connection between the source and destination. Go to the Connections tab to create a new connection. Select the Stripe source and Snowflake destination that you just created.

You will then see the following screen:

Choose a name for this connection, and choose your desired replication frequency. If you want to use the same naming as the source data in Stripe, then choose the “mirror source structure” option for your namespace configuration. Alternatively, you may define a prefix to be used in the destination.

Once you are satisfied with your configuration, press Set up connection and wait for the sync first to complete. Syncing all the namespaces can take a few minutes.

Once the sync has completed, you can look at the Databases tab in the Snowflake dashboard to confirm that the data has been replicated. You should see a page similar to the following:

You can now run advanced analytics and execute custom SQL queries on your Stripe data in Snowflake!

Wrapping up

Moving data from Stripe into Snowflake provides you with powerful analytics capabilities and allows you to see a full picture of your business. However, interacting with the Stripe REST API may require expert Stripe developers that know how to navigate Stripe developer docs. Furthermore, driving data into Snowflake may require understanding Snowflake's best practices and may need engineering resources and developer time. Alternatively you can use Airbyte to easily move your data from Stripe to Snowflake, as you have done in this tutorial.  Specifically, in this tutorial you have learned how to:

  1. Configure a Stripe account.
  2. Configure a Snowflake account by creating a new warehouse and database.
  3. Build an Airbyte connection between Stripe and Snowflake.
  4. Sync Stripe data to Snowflake.

If you have enjoyed this tutorial, you may be interested in other Airbyte tutorials, or in Airbyte’s blog. You can also join the conversation on our community Slack Channel, participate in discussions on Airbyte’s discourse, or sign up for our newsletter. Furthermore, if you are interested in Airbyte as a fully managed service, you can try Airbyte Cloud for free!

Open-source data integration

Get all your ELT data pipelines running in minutes with Airbyte.

Similar use cases

Replicate Salesforce data to BigQuery

Learn how to configure your Salesforce account to replicate leads data to BigQuery.

Copy Salesforce data to Snowflake

Learn how to use Airbyte Cloud to sync CRM data in Salesforce to Snowflake.