---
title: Connect Nuxt to Postgres on Neon
subtitle: Learn how to make server-side queries to Postgres using Nitro API routes
enableTableOfContents: true
updatedOn: '2025-10-31T11:07:57.606Z'
---
[Nuxt](https://nuxt.com/) is an open-source full-stack meta framework that enables Vue-based web applications. This topic describes how to connect a Nuxt application to a Postgres database on Neon.
To create a Neon project and access it from a Nuxt.js application:
## Create a Neon project
If you do not have one already, create a Neon project. Save your connection details including your password. They are required when defining connection settings.
1. Navigate to the [Projects](https://console.neon.tech/app/projects) page in the Neon Console.
2. Click **New Project**.
3. Specify your project settings and click **Create Project**.
## Create a Nuxt project and add dependencies
1. Create a Nuxt project if you do not have one. For instructions, see [Create a Nuxt Project](https://nuxt.com/docs/getting-started/installation#new-project), in the Nuxt documentation.
2. Add project dependencies using one of the following commands:
```shell
npm install pg
```
```shell
npm install postgres
```
```shell
npm install @neondatabase/serverless
```
## Store your Neon credentials
Add a `.env` file to your project directory and add your Neon connection string to it. You can find your connection string by clicking the **Connect** button on your **Project Dashboard** to open the **Connect to your database** modal. For more information, see [Connect from any application](/docs/connect/connect-from-any-app).
```shell shouldWrap
NUXT_DATABASE_URL="postgresql://:@.neon.tech:/?sslmode=require&channel_binding=require"
```
## Configure the Postgres client
First, make sure you load the `NUXT_DATABASE_URL` from your .env file in Nuxt’s runtime configuration:
In `nuxt.config.js`:
```javascript
export default defineNuxtConfig({
runtimeConfig: {
databaseUrl: ‘’,
},
});
```
Next, use the Neon serverless driver to create a database connection. Here’s an example configuration:
```javascript
import { neon } from '@neondatabase/serverless';
export default defineCachedEventHandler(
async (event) => {
const { databaseUrl } = useRuntimeConfig();
const db = neon(databaseUrl);
const result = await db`SELECT version()`;
return result;
},
{
maxAge: 60 * 60 * 24, // cache it for a day
}
);
```
- This example demonstrates using the Neon serverless driver to run a simple query. The `useRuntimeConfig` method accesses the `databaseUrl` set in your Nuxt runtime configuration.
- Async Handling: Make sure the handler is async if you are awaiting the database query result.
- Make sure `maxAge` caching fits your application’s needs. In this example, it’s set to cache results for a day. Adjust as necessary.
## Run the app
When you run `npm run dev` you can expect to see the following on [localhost:3000](localhost:3000):
```shell shouldWrap
PostgreSQL 16.0 on x86_64-pc-linux-gnu, compiled by gcc (Debian 10.2.1-6) 10.2.1 20210110, 64-bit
```
## Source code
You can find the source code for the applications described in this guide on GitHub.
Get started with Nuxt and Neon