Skip to main content

Runs a SQL command on SAP HANA Cloud using OAuth single sign on and returns a pandas or polars dataframe

Project description

Usage of the hana_cloud_interface package

This package provides a simple interface to connect to SAP HANA Cloud databases and execute SQL queries. Below are some examples of how to use the package.

initialising class

when initialising the class it has two optional args.

  • config_file : Path to the configuration file (JSON format) containing OAuth credentials and other settings. the config file only needs to be added on the first time running the class on a computer.

  • data_frame_type : Default data frame type for SQL query results. Options are 'pandas' or 'polars'. Default is 'pandas'. if the data type is not added here it will need to be added for every time you run hana_sql function

Hana_cloud_interface(config_file = 'location of configuration file',  df = 'pandas')

hana_sql() function

Execute a SQL command on the HANA Cloud database and return the result as a DataFrame.

Args: sql_command (str, optional): The SQL command to execute. Defaults to 'validate', which only checks the connection. DF_type_local_override (str, optional): DataFrame type for this query ('pandas' or 'polars'). Overrides the global setting if provided.

Returns: str: If sql_command is 'validate', returns a validation message. pandas.DataFrame or polars.DataFrame: The query result as a DataFrame, depending on the specified or default DataFrame type.

Raises: ValueError: If the DataFrame type is not specified or is invalid.

hana_upload() function

Upload a DataFrame to the HANA Cloud database.

Args: data (pandas.DataFrame or polars.DataFrame): The data to upload. If a polars DataFrame is provided, it will be converted to pandas. data_name (str): The name of the table to create or replace in HANA Cloud. SCHEMA (str): The schema in which to create the table.

Returns: bool: True if the upload is successful.

Raises: Exception: If the upload fails due to connection or data issues.

configuration file

the configuration file is a .json file

{
    "CLIENT_ID": "",
    "CLIENT_SECRET": "",
    "AUTH_URL": "",
    "TOKEN_URL": "",
    "protected_url": "",
    "REDIRECT_URI": "",
    "SCOPE": "",
	"HC_prod_URL": ""
}

example

the main function is very simple It takes a SQL command as a string and returns the data

import hana_cloud_interface 

# initialise class
hci = Hana_cloud_interface(df='polars')

sql_command = """
SELECT top 10
    "data1"
    "data2"
FROM "table1"
"""
    
data = hci.hana_sql(sql_command)

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

hana_cloud_interface-0.3.5.tar.gz (8.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

hana_cloud_interface-0.3.5-py3-none-any.whl (13.1 kB view details)

Uploaded Python 3

File details

Details for the file hana_cloud_interface-0.3.5.tar.gz.

File metadata

  • Download URL: hana_cloud_interface-0.3.5.tar.gz
  • Upload date:
  • Size: 8.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.9 {"installer":{"name":"uv","version":"0.10.9","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for hana_cloud_interface-0.3.5.tar.gz
Algorithm Hash digest
SHA256 f538b9246ab471f1a7066e7be98a90712023c8100065a9bab7853e1669742b5a
MD5 fb25d7256b7b4af674352175089f7596
BLAKE2b-256 c1345dd204c9a2ccc496e930ca980e873c509230138298e3e29520798b737d23

See more details on using hashes here.

File details

Details for the file hana_cloud_interface-0.3.5-py3-none-any.whl.

File metadata

  • Download URL: hana_cloud_interface-0.3.5-py3-none-any.whl
  • Upload date:
  • Size: 13.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.9 {"installer":{"name":"uv","version":"0.10.9","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for hana_cloud_interface-0.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 ae1c5b925c16f5dca166f02af02312ccbe20dca83d79e2da8f19d1b1691e38f0
MD5 ce27d0db272c1d53f4402ef7f32c6ece
BLAKE2b-256 46f5d5ab169cae9d0c36bde8c56050e58c0dff82bcfc1a5028e462876439de05

See more details on using hashes here.

Supported by

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