
Ice Pick#
Ice Pick is a Python package that provides utilities for common operations done on a Snowflake warehouse. Operations range from getting Snowflake object ddl, getting table statistics, and returning account level information.
Many utilities can be automatically packaged and deployed as stored procedures, so they can be executed natively in Snowflake.
Main Features#
Interact with schema objects with a Snowpark like interface.
In this initial development two data classes are available: SchemaObject and SchemaObjectFilter. The SchemaObject allows you to interact and retrieve information on the schema object, such as ddl, description, and grants.
The SchemaObjectFilter allows you to quickly return and inspect many schema objects. With the SchemaObjectFilter you can filter on specific databases, schemas, objects or object types using regex. Alternatively you can specify ignore filters to return all objects not in the filter.
Getting Started#
Read the docs: https://ice-pick.readthedocs.io/en/latest/#
install the library#
python -m pip install snowflake-ice-pick
create a snowpark session#
Ice pick extends the session to add the additional functionality
from snowflake.snowpark import Session
from ice_pick import extend_session
connection_parameters = {
"account": "<your snowflake account>",
"user": "<your snowflake user>",
"password": "<your snowflake password>",
"role": "<snowflake user role>",
"warehouse": "<snowflake warehouse>",
"database": "<snowflake database>",
"schema": "<snowflake schema>"
}
session = extend_session(Session).builder.configs(connection_parameters).create()
Example Usage#
Return the ddl, description, and grants for a schema object#
from ice_pick import SchemaObject
table_obj = session.create_schema_object('TEST', 'SCHEMA_1', 'CUSTOMER', 'TABLE')
# Get the ddl for the specified object
ddl = table_obj.get_ddl()
# Get the description of the object
description = table_obj.get_description()
# Get the grants on the object
grants_on = table_obj.get_grants_on()
# Grant the object to a role with permissions specified in a list
grant = table_obj.grant(["SELECT"], "PUBLIC")
Return bulk ddl for tables and procedures in the TEST database and the databases matching the TEST_* pattern#
from ice_pick import SchemaObject, SchemaObjectFilter
# create the fitler, where "*" are wildcards (regex supported)
obj_filter = session.create_schema_object_filter(
["TEST", "TEST_*"], # databases
[".*"], # schemas
[".*"], # object names
["tables", "Procedures"] # object types
)
# return the schema objects based on the filter
schema_object_list = sp_filter.return_schema_objects()
# Get the ddl for the returned schema objects
ddl_list = [schema_obj.get_ddl() for schema_obj in schema_object_list]
For further info check out Usage. Read installation instructions in Installation.
Warning
This library is still in the concept stage.