# 4. Database connection

Let's create the database connection in a separate file:

```js
// Contents of database.js

import knex from "knex";

const dbFile = "PATH_TO_YOUR_SQLITE_DB";

const knexInstance = knex({
  client: "sqlite3",
  connection: {
    filename: dbFile,
  },
});

export default knexInstance;
```

For Express to handle JSON requests, we need to add `app.use(express.json())` to `app.js`:

```js
// Contents of app.js

import express from "express";
const app = express();
const port = process.env.PORT || 3000;

app.use(express.json());

app.get("/", (req, res) => {
  res.send("Hello Class!");
});

// Rest of the file...
```

## Test the app

Run the main app. Can you access the database from your endpoint? To make sure, add a simple `knex` request in the endpoint.

## End file structure

At this point verify that your project structure looks like this:

* api
  * snippets.js
* app.js
* database.js
* package.json


---

# 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://program.hackyourfuture.dk/course-content/backend/node/week1/session-materials/04-database-connection.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.
