Skip to main content

llama-index vector-stores oceanbase integration

Project description

LlamaIndex Vector-Stores Integration: Oceanbase

OceanBase Database is a distributed relational database. It is developed entirely by Ant Group. The OceanBase Database is built on a common server cluster. Based on the Paxos protocol and its distributed structure, the OceanBase Database provides high availability and linear scalability.

OceanBase currently has the ability to store vectors. Users can easily perform the following operations with SQL:

  • Create a table containing vector type fields;
  • Create a vector index table based on the HNSW algorithm;
  • Perform vector approximate nearest neighbor queries;
  • ...

Limitations

The vector storage capability of OceanBase is still being enhanced, and currently has the following limitations:

  • Cosine vector distance function is not yet supported for vector index. Currently only inner product distance and Euclidean distance are supported, and Euclidean distance is used by default.
  • It should be noted that OceanBase currently only supports post-filtering (i.e., filtering based on metadata after performing an approximate nearest neighbor search).

Install dependencies

We use pyobvector to integrate OceanBase vector store into LlamaIndex. So it is necessary to install it with pip install pyobvector before starting.

Setup OceanBase

We recommend using Docker to deploy OceanBase:

docker run --name=ob433 -e MODE=slim -p 2881:2881 -d oceanbase/oceanbase-ce:4.3.3.0-100000142024101215

Usage

%pip install llama-index-vector-stores-oceanbase
%pip install llama-index
# choose dashscope as embedding and llm model, your can also use default openai or other model to test
%pip install llama-index-embeddings-dashscope
%pip install llama-index-llms-dashscope
from llama_index.vector_stores.oceanbase import OceanBaseVectorStore
from pyobvector import ObVecClient

client = ObVecClient()

client.perform_raw_text_sql(
    "ALTER SYSTEM ob_vector_memory_limit_percentage = 30"
)

# Initialize OceanBaseVectorStore
oceanbase = OceanBaseVectorStore(
    client=client,
    dim=1536,
    drop_old=True,
    normalize=True,
)

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

llama_index_vector_stores_oceanbase-0.3.0.tar.gz (8.5 kB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file llama_index_vector_stores_oceanbase-0.3.0.tar.gz.

File metadata

File hashes

Hashes for llama_index_vector_stores_oceanbase-0.3.0.tar.gz
Algorithm Hash digest
SHA256 92f0733b997962a89a6f0c4fdaed6acd30a0fc354cffdf7dbfb2d594fba924b6
MD5 6bff409be90f0cecb64a9dc7953b3d68
BLAKE2b-256 adbd2c3ec5058a21d2b6a631be28f9b872991aef0a72fe8feda1e6f846680798

See more details on using hashes here.

File details

Details for the file llama_index_vector_stores_oceanbase-0.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for llama_index_vector_stores_oceanbase-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ef993db9d053c6c4d6091eb4dfdec453a10285790eca6023a45810faea55803a
MD5 6db3dacb43e48c16c0020ec070706ddd
BLAKE2b-256 d9a2bab3ee3ddbec7a3dd917f28a923241019558ed71ba6cddb4eacaef32dc90

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