Files
ersteller/schema/ent/example/start.go
T
2025-09-12 01:54:21 +02:00

64 lines
1.6 KiB
Go

package main
import (
"context"
"ersteller-lib/schema/ent/example/ent"
"log"
"time"
_ "github.com/mattn/go-sqlite3"
)
func main() {
//client, err := ent.Open("sqlite3", "file:ent?mode=memory&cache=shared&_fk=1")
client, err := ent.Open("sqlite3", "/tmp/ersteller_ent_example.db?_fk=1",
ent.Log(log.Println), ent.Debug())
if err != nil {
log.Fatalf("failed opening connection to sqlite: %v", err)
}
log.Println("client", client)
defer client.Close()
ctx, cancel := context.WithTimeout(context.Background(), time.Minute*5)
defer cancel()
if err := client.Schema.Create(ctx); err != nil {
log.Fatalf("failed creating schema resources: %v", err)
}
u, err := client.User.
Create().
SetEmail("something@gorlug.de").
SetPassword("uhoh").Save(ctx)
if err != nil {
log.Fatalf("failed creating user: %w", err)
}
log.Println("user was created: ", u)
//time.Sleep(time.Second * 1)
//u, err = client.User.UpdateOneID(u.ID).SetPassword("wtf").Save(ctx)
//if err != nil {
// log.Fatalf("failed updating user: %w", err)
//}j
//log.Println("user was updated", u)
query := client.User.Query()
users, nextId, hasNext, err := query.PaginateAfterID(ctx, 0, 2)
if err != nil {
log.Fatalf("failed listing users: %w", err)
}
if hasNext {
log.Println("next id", nextId)
for _, u := range users {
log.Println("user", u.ID, u.Email, u.Password)
}
}
users, nextId, hasNext, err = query.PaginateAfterID(ctx, nextId, 2)
if err != nil {
log.Fatalf("failed listing users: %w", err)
}
if hasNext {
log.Println("2 next id", nextId)
for _, u := range users {
log.Println("2 user", u.ID, u.Email, u.Password)
}
}
}