Connecting to Vertica#
Data Science & AI Workbench enables you to easily connect to HP Vertica, a distributed analytics database that stores data in column format.
Before you can do so, you’ll need to conda install the vertica-python
package, which contains the Python adapter for Vertica databases:
conda install --channel conda-forge vertica-python
Note
Any packages you install from the command line are available during the current session only. If you want them to persist, add them to the project’s anaconda-project.yml
file. For more information, see Project configurations.
You can then use code such as this to import the library and connect to Vertica from within a notebook session:
import vertica_python
import json
# Get credentials from Kubernetes. The credentials were setup as a dictionary
credentials = None
with open('/var/run/secrets/user_credentials/vertica_credentials') as f:
credentials = json.load(f)
# Verify the credentials were pulled correctly
if credentials:
# Set up connection dictionary based on secrets obtained above
connection_info = {
'host': credentials.get('hostname'),
'port': 5433,
'user': credentials.get('username'),
'password': credentials.get('password'),
'database': 'VMart'
}
# Use a with statement that auto closes the connection once out of the loop
with vertica_python.connect(**connection_info) as connection:
cursor = connection.cursor()
# Set up example query for the sample dataset that is being used
example_query = (
"SELECT DISTINCT s.product_key, p.product_description "
"FROM store.store_sales_fact s, public.product_dimension p "
"WHERE s.product_key = p.product_key "
"AND s.product_version = p.product_version AND s.store_key IN ("
" SELECT store_key "
" FROM store.store_dimension "
" WHERE store_state = 'MA') "
"ORDER BY s.product_key LIMIT 50;"
)
# Execute the query
cursor.execute(example_query)
# Iterate through the cursor and print each row
for row in cursor.iterate():
print(row)