Skip to main content

Snowflake SQL API V2

Project description

Snowflake SQL API Client

The Snowflake SQL API is a REST API that you can use to access and update data in a Snowflake database.

Contact Support - Email: tungnq@gmail.com

Requirements.

Python 2.7 and 3.4+

Installation & Usage

Install a Virtual Environment using Venv

pip install virtualenv

Go to project folder

python -m venv env

Activate the Virtual Environment

 env/Scripts/activate.bat //In CMD
 env/Scripts/Activate.ps1 //In Powershel

pip install

pip install -r requirements.txt

If the python package is hosted on Github, you can install directly from Github

pip install git+https://github.com/GIT_USER_ID/GIT_REPO_ID.git

(you may need to run pip with root permission: sudo pip install git+https://github.com/GIT_USER_ID/GIT_REPO_ID.git)

Then import the package:

import snowflake_sql_api_client 

Setuptools

Install via Setuptools.

python setup.py install --user

(or sudo python setup.py install to install the package for all users)

Then import the package:

import snowflake_sql_api_client

Generate the distribution archives on local machine - https://towardsdatascience.com/how-to-publish-a-python-package-to-pypi-7be9dd5d6dcd

Upgrade setuptools wheel

python -m pip install –-user –-upgrade setuptools wheel

Generate the distribution files.

python setup.py sdist bdist_wheel

Install the package on local machine.

pip install -e .

Publish the package to the PyPi repository

python -m twine upload dist/*

Getting Started

Please follow the installation procedure and then run the following:

from __future__ import print_function
import time
import snowflake_sql_api_client
from snowflake_sql_api_client.rest import ApiException
from pprint import pprint

from snowflake_sql_api_client.utilities.sql_api_generate_jwt import JWTGenerator 

# Generate JWT Token
jwt_token = JWTGenerator(
    account=[YOUR SNOWFLAKE HOST]
    , user=[YOUR USERNAME]
    , private_key=[YOUR USENAME PRIVATE_KEY]
    , lifetime=timedelta(minutes=lifetime_in_minutes)
    , renewal_delay=timedelta(minutes=renewal_delay_in_minutes)
    ).get_token()

# Configure API key authorization: bearerAuth
configuration = snowflake_sql_api_client.Configuration()
configuration.api_key['Authorization'] = jwt_token
# Uncomment below to setup prefix (e.g. Bearer) for API key, if needed
configuration.api_key_prefix['Authorization'] = 'Bearer'

# create an instance of the API class
api_instance = snowflake_sql_api_client.Apiv2statementsApi(snowflake_sql_api_client.ApiClient(configuration))
body = NULL # object |  (optional)
user_agent = 'user_agent_example' # str | (Required) Set this to the name and version of your application (e.g. “applicationName/applicationVersion”). You must use a value that complies with RFC 7231. (optional)
x_snowflake_authorization_token_type = 'x_snowflake_authorization_token_type_example' # str | Specify the authorization token type for the Authorization header. KEYPAIR_JWT is for Keypair JWT or OAUTH for oAuth token. If not specified, OAUTH is assumed. (optional)
content_type = 'content_type_example' # str |  (optional)
accept = 'accept_example' # str |  (optional)
request_id = 'request_id_example' # str | Unique ID of the API request. This ensures that the execution is idempotent. If not specified, a new UUID is generated and assigned. (optional)
_async = '_async_example' # str | Set to true to execute the statement asynchronously and return the statement handle. If the parameter is not specified or is set to false, a statement is executed and the first result is returned if the execution is completed in 45 seconds. If the statement execution takes longer to complete, the statement handle is returned. (optional)
nullable = 'nullable_example' # str | Set to true to execute the statement to generate the result set including null. If the parameter is set to false, the result set value null will be replaced with a string 'null'. (optional)

try:
    # Submits a SQL statement for execution.
    api_response = api_instance.api_v2_statements_post(body=body, user_agent=user_agent, x_snowflake_authorization_token_type=x_snowflake_authorization_token_type, content_type=content_type, accept=accept, request_id=request_id, _async=_async, nullable=nullable)
    pprint(api_response)
except ApiException as e:
    print("Exception when calling Apiv2statementsApi->api_v2_statements_post: %s\n" % e)

Documentation for API Endpoints

All URIs are relative to https://virtserver.swaggerhub.com/Home4677/Snowflake_SQL_API_V2/1.0.0

Class Method HTTP request Description
Apiv2statementsApi api_v2_statements_post POST /api/v2/statements Submits a SQL statement for execution.
Apiv2statementsStatementHandleApi api_v2_statements_statement_handle_cancel_post POST /api/v2/statements/{statementHandle}/cancel Cancels the execution of a statement.
Apiv2statementsStatementHandleApi api_v2_statements_statement_handle_get GET /api/v2/statements/{statementHandle} Checks the status of the execution of a statement

Documentation For Models

Documentation For Authorization

bearerAuth

  • Type: API key
  • API key parameter name: Authorization
  • Location: HTTP header

Author

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

snowflake-sql-api-client-2.0.6.tar.gz (21.5 kB view details)

Uploaded Source

Built Distribution

snowflake_sql_api_client-2.0.6-py3-none-any.whl (27.2 kB view details)

Uploaded Python 3

File details

Details for the file snowflake-sql-api-client-2.0.6.tar.gz.

File metadata

File hashes

Hashes for snowflake-sql-api-client-2.0.6.tar.gz
Algorithm Hash digest
SHA256 b78f4afdc677c075d9cb3386c378711e9d36fa1766d4256b54c47de89b1eff52
MD5 2ba0be8b87f61e68d27bbe80a817d537
BLAKE2b-256 174e4e33d17c45cf4ef5d8d6938433dfb84ac981d4088276f0c2d21d93bd9489

See more details on using hashes here.

File details

Details for the file snowflake_sql_api_client-2.0.6-py3-none-any.whl.

File metadata

File hashes

Hashes for snowflake_sql_api_client-2.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 7085d5b8476b475e77735c6f0c7ef8e606acd5f05a6dddc83d7497784e463557
MD5 048b186ea1b41676e75e81810dd0c630
BLAKE2b-256 dfc5a6c52668d06d21347d4bbd21d18888152d6c18325702369a6cf078844fbf

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page