upstash / vector
An HTTP/REST based Vector DB client built on top of Upstash REST API.
Installs: 1 221
Dependents: 1
Suggesters: 0
Security: 0
Stars: 6
Watchers: 7
Forks: 0
Open Issues: 3
Requires
- php: ^8.3
- nyholm/psr7: ^1.8
- php-http/discovery: ^1.20.0
- psr/http-client: ^1.0.3
- psr/http-client-implementation: *
- psr/http-factory-implementation: *
- psr/http-message: ^2.0.0
Requires (Dev)
- brianium/paratest: ^7.4
- laravel/pint: ^1.0
- nunomaduro/collision: ^8.5
- phpstan/phpstan: ^2.1
- phpunit/phpunit: ^11.5.6
- robiningelbrecht/phpunit-pretty-print: ^1.3
- spatie/ray: ^1.28
- symfony/http-client: ^7.2
- vlucas/phpdotenv: ^5.6
- dev-master
- v1.2.0
- v1.1.0
- v1.0.1
- v1.0.0
- v0.2.1
- v0.2.0
- v0.1.7
- v0.1.6
- v0.1.5
- v0.1.4
- v0.1.3
- v0.1.2
- v0.1.1
- v0.1.0
- dev-dependabot/composer/phpunit/phpunit-tw-12.1.5
- dev-dependabot/composer/phpunit/phpunit-tw-12.1.4
- dev-transporter-plugins
- dev-dx-1668
- dev-introduce-rector
- dev-experimental-semantic-cache
- dev-range-vectors
- dev-sparse-hybrid-fetch-missing-vectors
- dev-dependabot/composer/phpunit/phpunit-tw-11.5.3
This package is not auto-updated.
Last update: 2025-05-23 12:12:58 UTC
README
Upstash Vector is an HTTP serverless Vector Database.
You can store, query, and retrieve vectors from your application, use it to power your search, and more.
You can read more about Upstash Vector here.
Quick Start
Installation
You can install the package via composer:
composer require upstash/vector
Create Index
Create a new index on Upstash
Usage
Initialize the index
use Upstash\Vector\Index; // Initialize the index $index = new Index( url: 'UPSTASH_VECTOR_REST_URL', token: 'UPSTASH_VECTOR_REST_TOKEN', ); // or just to use the environment variables $index = Index::fromEnv();
Upserting Vectors
use Upstash\Vector\Index; use Upstash\Vector\VectorUpsert; use function Upstash\Vector\createRandomVector; $index = new Index( url: 'UPSTASH_VECTOR_REST_URL', token: 'UPSTASH_VECTOR_REST_TOKEN', ); $index->upsert(new VectorUpsert( id: 'upstash-rocks', vector: createRandomVector(dimensions: 1536), metadata: ['field' => 'value'], ));
Upserting Data with Embedding Models
use Upstash\Vector\Index; use Upstash\Vector\DataUpsert; $index = new Index( url: 'UPSTASH_VECTOR_REST_URL', token: 'UPSTASH_VECTOR_REST_TOKEN', ); $index->upsertData(new DataUpsert( id: 'upstash-vector', data: 'Upstash Vector is a serverless vector database.', metadata: ['field' => 'value'], ));
Querying Vectors
use Upstash\Vector\Index; use Upstash\Vector\VectorQuery; use function Upstash\Vector\createRandomVector; $index = new Index( url: 'UPSTASH_VECTOR_REST_URL', token: 'UPSTASH_VECTOR_REST_TOKEN', ); $index->query(new VectorQuery( vector: createRandomVector(dimensions: 1536), topK: 5, ));
Querying Data with Embedding Models
use Upstash\Vector\Index; use Upstash\Vector\DataQuery; $index = new Index( url: 'UPSTASH_VECTOR_REST_URL', token: 'UPSTASH_VECTOR_REST_TOKEN', ); $index->queryData(new DataQuery( data: 'What is Upstash Vector?', topK: 5, ));
Fetch specific vectors
use Upstash\Vector\Index; use Upstash\Vector\VectorFetch; $index = new Index( url: 'UPSTASH_VECTOR_REST_URL', token: 'UPSTASH_VECTOR_REST_TOKEN', ); $index->fetch(new VectorFetch(ids: ['upstash-rocks']));
Delete specific vectors
use Upstash\Vector\Index; $index = new Index( url: 'UPSTASH_VECTOR_REST_URL', token: 'UPSTASH_VECTOR_REST_TOKEN', ); $index->delete(['upstash-rocks']);
Namespaces
Upstash Vector allows you to partition a single index into multiple isolated namespaces. Each namespace functions as a self-contained subset of the index, in which read and write requests are only limited to one namespace. To learn more about it, see Namespaces.
Example
use Upstash\Vector\Index; use Upstash\Vector\VectorUpsert; use function Upstash\Vector\createRandomVector; $index = new Index( url: 'UPSTASH_VECTOR_REST_URL', token: 'UPSTASH_VECTOR_REST_TOKEN', ); // Upsert to namespace $index->namespace('books')->upsert(new VectorUpsert( id: 'upstash-rocks', vector: createRandomVector(dimensions: 1536), metadata: ['field' => 'value'], ));
Troubleshooting
We have a Discord for common problems. If you can't find a solution, please open an issue.
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.