PostgreSQL extension with builtin RAG capabilities, enabling the interpretation and querying of data through both natural language and SQL functions.
The pg_ai extension brings the power of AI and LLMs to SQL. pg_ai helps in:
(i) Facilitating natural language interaction with datasets: Transforming query results from PostgreSQL tables into a vector store, enabling interactions with the store through natural language.
(ii) Interpreting data stored in PostgreSQL tables using generative AI: Leveraging LLMs' continual learning and evolving capabilities to gain fresh insights into data, providing new interpretations over time and with each query (Single Datum, Multiple Inferences SDMI),
cd pg_ai
make install
- pg_ai uses libcurl for communication with remote AI services, curl needs to be installed.
- needs pgvector extension for vector operations.
CREATE EXTENSION pg_ai;
Choose the AI service
SET pg_ai.service = 'OPenAI'(default)|'Gemini';
Set the API Key OpenAI or Google AI Studio
SET pg_ai.api_key='qz********y';
Get the column data interpreted by LLM.
SELECT col1, col2, pg_ai_insight(col1) AS insight FROM my_table WHERE id > 5;
Aggregate version of the above function.
SELECT pg_ai_insight_agg(col1, 'Suggest a topic for these values') AS topic FROM my_table WHERE id > 5;
Create vector store for a dataset.
SELECT pg_ai_create_vector_store(store => 'movies_vec_store_90s',
query => 'SELECT * FROM public.movies WHERE release_year > 1990',
notes => 'movies released after 1990');
Query the vector store with a natural language prompt.
SELECT pg_ai_query_vector_store(store => 'movies_vec_store_90s',
prompt => 'movies on time travel',
count => 3);
SET pg_ai.similarity_algorithm='cosine'(default)|'euclidean'|'inner_product';
Get the moderations for the column data.
SELECT col1, pg_ai_moderation(col1, NULL) FROM messages_table WHERE id=1;
Aggregate version of the above function.
SELECT pg_ai_moderation_agg(col1, NULL) FROM messages_table WHERE id<10;
SELECT pg_ai_help();
Models in use.
- OpenAI - gpt-3.5-turbo-instruct
- OpenAI - text-embedding-ada-002
- OpenAI - text-moderation-stable
- OpenAI - dall-e-3
- Google AI- gemini-pro:generateContent
- Develop parallelization framework for loading embedding vectors in the background.
- Improve curl read callbacks and add tokenization support to handle longer context data.
- Enable customization to utilize alternative local and remote LLMs.
- Separate storage layer to enable the creation and querying of remote vector stores,(object stores/dbs, file-based storage).
- Explore new vector index type (HNTW).
- Introduce the extension catalog.
This is not a official extension. All trademarks and copyrights are the property of their respective owners.
The response received from the AI service is not interpreted or modified by the extension, it is presented as received.