![]() |
VOOZH | about |
There are a vast number of PostgreSQL clients available on the Internet. From standard Drivers to BI and Analytics tools, PostgreSQL is a popular interface for data access. Using our JDBC Drivers, you can now create PostgreSQL entry-points that you can connect to from any standard client.
To access Pinecone data as a PostgreSQL database, use the CData JDBC Driver for Pinecone and a JDBC foreign data wrapper (FDW). In this article, we compile the FDW, install it, and query Pinecone data from PostgreSQL Server.
To connect to Pinecone as a JDBC data source, you will need the following:
Driver class:
cdata.jdbc.api.APIDriver
To authenticate to Pinecone, and connect to your own data or to allow other users to connect to their data, you can use API Key authentication.
To authenticate using an API Key, you need to obtain your API Key from your Pinecone console at https://app.pinecone.io/.
You can then connect by setting the AuthScheme to APIKey and providing your API key:
Standard API Key Configuration:
Profile=C:\profiles\Pinecone.apip;AuthScheme=APIKey;ProfileSettings='APIKey=your_api_key;APIVersion=2025-10';
For assistance in constructing the JDBC URL, use the connection string designer built into the Pinecone JDBC Driver. Either double-click the JAR file or execute the jar file from the command-line.
java -jar cdata.jdbc.api.jar
Fill in the connection properties and copy the connection string to the clipboard.
👁 Using the built-in connection string designer to generate a JDBC URL (Salesforce is shown.)A typical JDBC URL is below:
jdbc:api:Profile=C:\profiles\Pinecone.apip;AuthScheme=APIKey;ProfileSettings='APIKey=your_api_key;APIVersion=2025-10';
The Foreign Data Wrapper can be installed as an extension to PostgreSQL, without recompiling PostgreSQL. The jdbc2_fdw extension is used as an example (downloadable here).
ln -s /usr/lib/jvm/java-6-openjdk/jre/lib/amd64/server/libjvm.so /usr/lib/libjvm.so
make install USE_PGXS=1
After you have installed the extension, follow the steps below to start executing queries to Pinecone data:
CREATE EXTENSION jdbc2_fdw;
CREATE SERVER API FOREIGN DATA WRAPPER jdbc2_fdw OPTIONS ( drivername 'cdata.jdbc.api.APIDriver', url 'jdbc:api:Profile=C:\profiles\Pinecone.apip;AuthScheme=APIKey;ProfileSettings='APIKey=your_api_key;APIVersion=2025-10';', querytimeout '15', jarfile '/home/MyUser/CData/CData\ JDBC\ Driver\ for\ Salesforce MyDriverEdition/lib/cdata.jdbc.api.jar');
CREATE USER MAPPING for postgres SERVER API OPTIONS ( username 'admin', password 'test');
postgres=# CREATE FOREIGN TABLE indexes ( indexes_id text, indexes_ text, indexes_ numeric) SERVER API OPTIONS ( table_name 'indexes');
postgres=# SELECT * FROM indexes;
Connect to live data from Pinecone with the API Driver
Connect to Pinecone