Streamlit Xata Data Base ConnectionAn easy way to connect your Streamlit application to your Xata database.
Project description
st-xatadb-connection
Xata Data Base Connection Streamlit
Getting Started with st_xata_connection
1. Set up your Xata.io and Streamlit Environment
-
Create a Xata account and database at Xata Web.
-
Generate an API key for your Xata database.
-
Get your Xata database URL endpoint.
-
Install Streamlit by running
pip install streamlit
. -
Install st_xata_connection by running
pip install st-xata-connection
.** not published yet.
2. Configure your Xata Credentials
To securely store your Xata API key and database URL, you can use Streamlit's secrets manager or environment variables.
XATA_API_KEY = "YOUR_XATA_API_KEY"
DATABASE_URL = "YOUR_XATA_DATABASE_URL"
3. Connect to your Xata.io Database
Import the st_xata_connection
package and use the st.connection() function to connect to your Xata database.
You could also use the the st.session_state
object to store the connection object and reuse it across your Streamlit app.
import streamlit as st
from st_xata_connection import XataConnection
xata = st.connection('xata', type=XataConnection)
4. Query your Xata.io Database
Use the xata.query()
function to query your Xata.io database.
results = xata.query("Table_Name")
5. Display your Query Results
Use Streamlit functions like st.write()
, st.table()
,st.json()
, or st.dataframe()
to display your query results in your Streamlit app.
st.write(results)
6. Insert, Update, and Delete Data
You can also use st_xatadb_connection to insert, update, and delete data in your Xata.io database.
record = {
"name": "John Doe",
"age": 30,
"email": "a@b.com"
}
response = xata.insert("Table_Name", record)
The xata.insert()
function returns a response object that contains the information about the inserted record.
It looks like this:
{
"id": "rec_c8hnbch26un1nl0rthkg",
"xata": {
"version": 0,
"createdAt": "2023-05-15T08:21:31.96526+01:00",
"updatedAt": "2023-05-15T21:58:54.072595+01:00"
}
}
where id
is the unique identifier of the inserted record, and xata
contains the metadata about the record.
Now we can use the id
to update the record or delete it. And in the same way, these functions also return a response object
that contains the information about the updated or deleted record.
update_response = xata.update("Table_Name", "rec_c8hnbch26un1nl0rthkg", {"age": 31})
delete_response = xata.delete("Table_Name", "rec_c8hnbch26un1nl0rthkg")
7. Working with files
Xata supports file uploads and downloads. You can use the xata.upload_file()
function to upload a file to your Xata database
or the xata.get_file()
function to download a file from your Xata database.
Suppose you have a file called my_avatar.png
in your current working directory. You can upload it to your Xata database like this:
upload_response = xata.upload_file("Table_Name", "rec_c8hnbch26un1nl0rthkg", "column_name", "my_avatar_bas64_encoded")
Now you can download the file from your Xata database like this:
download_response = xata.get_file("Table_Name", "rec_c8hnbch26un1nl0rthkg", "column_name")
8. Transactions
If you want to perform multiple operations on your Xata database as a single unit of work, you can use transactions.
For this, you can use the xata.transaction()
function. It takes a list of operations as an argument and returns a response object.
Suppose you want to insert a record and update another record in your Xata database as a single unit of work. You can do it like this:
transaction_response = xata.transaction([
{"insert": {"table": "Table_Name", "record": {"name": "Marie Doe", "age": 21, "email": "marie@mail.com"}}}
{"update": {"table": "Table_Name", "id": "rec_c8hnbch26un1nl0rthkg", "fields": {"age": 31}}}
{"get": {"table": "Table_Name", "id": "rec_c8hnbch26un1nl0rthkg","columns": ["name", "age"]}}
{"delete": {"table": "Table_Name", "id": "rec_c8hnbch26un1nl0rthkg"}}
])
Note that the transaction()
function takes a list of operations as an argument. Each operation is a dictionary that contains
the type of operation and the operation-specific arguments. The supported operations are insert
, update
, get
, and delete
.
9. SQL Queries
If you feel more comfortable with SQL, you can use the xata.sql_query()
function to query your Xata database using SQL.
The xata.sql_query()
function takes a SQL query as an argument and returns a response object with the query results.
For example, suppose you want to query your Xata database using SQL. You can do it like this:
sql_response = xata.sql_query("SELECT * FROM Table_Name")
10. Asking to the AI Assistant
Xata has an AI assistant that can help you with your queries. You can use the xata.askai()
function to ask a question to the AI assistant,
taking a reference to the table you want to query and the question you want to ask as arguments.
Suppose you want to ask the AI assistant to find the people in your table whose age is greater than 30. You can do it like this:
response = xata.askai("Table_Name", "Find the people whose age is greater than 30")
The response looks like this:
{
"answer": "< answer >",
"sessionId": "cg52bk1eqh5rd5hndhq95jercs",
"records": [
"b70d541d114ff54ad15915636450663f",
"8ae4837002e21f013aa85c30a126ea1c",
"4b137344a3c53d5152c45ed514188cd2"
]
}
The st_xata_connection
package is a powerful tool that makes it easy to connect your Streamlit app to your Xata database.
In this article, we've covered the basics of using st_xata_connection
to query your Xata database, insert, update, and delete data,
work with files, perform transactions, and ask questions to the AI assistant. But there's a lot more you can do with st_xata_connection
.
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
Built Distribution
File details
Details for the file st-xatadb-connection-1.0.0.tar.gz
.
File metadata
- Download URL: st-xatadb-connection-1.0.0.tar.gz
- Upload date:
- Size: 4.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d57aeb23be722ceac9bfc1cb3e64513e813e17297561be26e372e8f4bf6d995c |
|
MD5 | f6f99f41a0ab776fa1bed597c40e35cf |
|
BLAKE2b-256 | b697e140193479d651c09ce28bb26e5fad78cd92e16e23cbfd46b1625619a846 |
File details
Details for the file st_xatadb_connection-1.0.0-py3-none-any.whl
.
File metadata
- Download URL: st_xatadb_connection-1.0.0-py3-none-any.whl
- Upload date:
- Size: 4.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a33af82fdd982c7614a20127d2d5f5d700958b818b4431f638a8fa3ce70a9990 |
|
MD5 | 2579b539301b7cd9cff5ab7aad345499 |
|
BLAKE2b-256 | 4eacfe41ed4a123465fbc127c849a759e36436a6e802e12bdb10137e29bca16c |