Introducción

Para esta actividad tienes este proyecto de ayuda: https://gitlab.com/xtec/kotlin/postgres/

Entorno de trabajo

Crea un proyecto:

> mkdir postgres
> cd postgres
> gradle init --package dev.xtec --project-name postgres --java-version 21 --type kotlin-application --dsl kotlin --test-framework kotlintest --no-split-project --no-incubating --overwrite

Modifica el fichero app/build.gradle.kts:

plugins {
    id("app.cash.sqldelight") version "2.0.2"
    // ...
}

dependencies {
    implementation("app.cash.sqldelight:jdbc-driver:2.0.2")
    implementation("com.zaxxer:HikariCP:6.2.1")
    implementation("io.github.cdimascio:dotenv-kotlin:6.5.0")
    implementation("org.postgresql:postgresql:42.5.0")
    implementation("org.slf4j:slf4j-reload4j:2.0.16")
    // ...
}

sqldelight {
    databases {
        create("Database") {
            packageName.set("dev.xtec.data")
            dialect("app.cash.sqldelight:sqlite-3-38-dialect:2.0.2")
        }
    }
}

Añade un fichero log4j.properties en el directorio app/src/main/resources para configurar slf4j:

# Root logger option
log4j.rootLogger=INFO, stdout
# Direct log messages to stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

Configura el esquema

Crea el directorio app/src/main/sqldelight/dev/xtec/data para poner los ficheros .sq

Añade un fichero Customer.sq:

CREATE TABLE IF NOT EXISTS customer (
    id SERIAL PRIMARY KEY,
    name TEXT NOT NULL,
    email TEXT
);

insert:
INSERT INTO customer(name) VALUES (?);

select:
SELECT * FROM customer;

Genera el código de acceso a la base de datos:

>  .\gradlew generateSqlInterface 

Crea el fichero app/src/main/resources/.env para guardar los datos de configuración de la base de datos (este fichero no tiene que estar versionado):

PG_JDBC_URL = jdbc:postgresql://localhost:5432/acme
PG_USERNAME = postgres
PG_PASSWORD = password

Modifica el fichero app/src/main/kotlin/dev/xtec/App.kt:

package dev.xtec

import app.cash.sqldelight.db.SqlDriver
import app.cash.sqldelight.driver.jdbc.asJdbcDriver
import com.zaxxer.hikari.HikariDataSource
import dev.xtec.data.Database
import io.github.cdimascio.dotenv.dotenv

fun main() {
   
    val dotenv = dotenv()

    val driver: SqlDriver = HikariDataSource().apply {
        jdbcUrl = dotenv["PG_JDBC_URL"]
        driverClassName = "org.postgresql.Driver"
        username = dotenv["PG_USERNAME"]
        password = dotenv["PG_PASSWORD"]
    }.asJdbcDriver()

    val database = Database(driver)
    Database.Schema.create(driver)

    database.customerQueries.insert("Laura")

    val customer = database.customerQueries.select().executeAsList().first()
    println(customer)

}

Base de datos

Arranca una base de datos tal com se explica en Postgres.

Crea una base de datos con el nombre de acme.

Ejecuta la aplicación:

> .\gradlew run                                                                           
...

Customer(id=1, name=Laura, email=null)

Neon

Crea una base de datos en Neon.

A continuación modifica el fichero .venv con los datos de conexión de neon.

Por ejemplo:

PG_JDBC_URL = jdbc:postgresql://ep-ancient-recipe-a9qwtikr.gwc.azure.neon.tech/sales
PG_USERNAME = sales_owner
PG_PASSWORD = npg_pnZrJxz87UiC

Verifica que el codigo funciona sin modificar ninguna linea de código.