
- Create a new pipeline or open an existing pipeline.
- Expand the left side of your screen to view the file browser.
- Scroll down and click on a file named
io_config.yaml
.
- Enter the following keys and values under the key named
default
(you can have multiple
profiles, add it under whichever is relevant to you)
version: 0.1.1
default:
SNOWFLAKE_USER: ...
SNOWFLAKE_PASSWORD: ...
SNOWFLAKE_ACCOUNT: ...
SNOWFLAKE_DEFAULT_WH: ...
- Create a new pipeline or open an existing pipeline.
- Add a data loader, transformer, or data exporter block.
- Select
SQL
.
- Under the
Data provider
dropdown, select Snowflake
.
- Under the
Profile
dropdown, select default
(or the profile you added credentials underneath).
- Next to the
Database
label, enter the database name you want this block to save data to.
- Next to the
Save to schema
label, enter the schema name you want this block to save data to.
- Under the
Write policy
dropdown, select Replace
or Append
(please see SQL blocks guide for more information on write policies).
- Enter in this test query:
SELECT 1
.
- Run the block.
- Create a new pipeline or open an existing pipeline.
- Add a data loader, transformer, or data exporter block
(the code snippet below is for a data loader).
- Select
Generic (no template)
.
- Enter this code snippet
(note: change the
config_profile
from default
if you have a different profile):
from mage_ai.data_preparation.repo_manager import get_repo_path
from mage_ai.io.config import ConfigFileLoader
from mage_ai.io.snowflake import Snowflake
from os import path
from pandas import DataFrame
if 'data_loader' not in globals():
from mage_ai.data_preparation.decorators import data_loader
@data_loader
def load_data_from_snowflake(**kwargs) -> DataFrame:
query = 'SELECT 1'
config_path = path.join(get_repo_path(), 'io_config.yaml')
config_profile = 'default'
with Snowflake.with_config(ConfigFileLoader(config_path, config_profile)) as loader:
return loader.load(query)
- Run the block.