# PostgreSQL database

For the application database, Fabricate requires PostgreSQL 16 or later.

We recommend that you host the PostgreSQL database on a managed service such as [Amazon RDS](https://aws.amazon.com/rds/) or [Google Cloud SQL](https://cloud.google.com/sql). However, you can also host the database on the same machine.

## Creating the database and user <a href="#database-create" id="database-create"></a>

```
create user fabricate WITH PASSWORD '<your password>';
create database fabricate owner fabricate;
alter user fabricate with SUPERUSER;
```

When Fabricate starts, it automatically creates the database tables.

## Configuring the connection to the database <a href="#database-env-var" id="database-env-var"></a>

After you create your database, in `.env`, to configure the connection to the database, set the following environment variables:

{% code overflow="wrap" %}

```
FABRICATE_DATABASE_NAME="fabricate"
FABRICATE_DATABASE_USERNAME="fabricate"
FABRICATE_DATABASE_PASSWORD="<your password>"
FABRICATE_DATABASE_HOST="<database hostname>" # for example, fabricate.abcdefghijkl.us-east-1.rds.amazonaws.com
```

{% endcode %}


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.tonic.ai/fabricate/self-hosting-fabricate/configuring-fabricate/postgresql-database.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
