jet/examples/quick-start/quick-start.go

119 lines
2.5 KiB
Go
Raw Normal View History

2019-06-24 18:22:55 +02:00
package main
import (
"database/sql"
"encoding/json"
"fmt"
"os"
2019-06-24 18:22:55 +02:00
2021-05-17 14:54:26 +02:00
_ "github.com/lib/pq"
2020-05-31 10:42:55 +02:00
// dot import so that jet go code would resemble as much as native SQL
2019-07-17 13:22:14 +02:00
// dot import is not mandatory
2020-06-27 18:48:19 +02:00
. "github.com/go-jet/jet/v2/examples/quick-start/.gen/jetdb/dvds/table"
. "github.com/go-jet/jet/v2/postgres"
2019-06-24 18:22:55 +02:00
2020-06-27 18:48:19 +02:00
"github.com/go-jet/jet/v2/examples/quick-start/.gen/jetdb/dvds/model"
)
const (
2019-08-17 14:49:35 +02:00
host = "localhost"
port = 5432
user = "jet"
password = "jet"
dbName = "jetdb"
2019-06-24 18:22:55 +02:00
)
func main() {
// Connect to database
2019-08-17 14:49:35 +02:00
var connectString = fmt.Sprintf("host=%s port=%d user=%s password=%s dbname=%s sslmode=disable", host, port, user, password, dbName)
db, err := sql.Open("postgres", connectString)
2019-06-24 18:22:55 +02:00
panicOnError(err)
defer db.Close()
// Write query
2019-06-24 18:22:55 +02:00
stmt := SELECT(
2019-07-17 13:22:14 +02:00
Actor.ActorID, Actor.FirstName, Actor.LastName, Actor.LastUpdate,
Film.AllColumns,
2022-02-11 12:49:54 +01:00
Language.AllColumns.Except(Language.LastUpdate),
2019-06-24 18:22:55 +02:00
Category.AllColumns,
).FROM(
Actor.
2019-07-17 13:22:14 +02:00
INNER_JOIN(FilmActor, Actor.ActorID.EQ(FilmActor.ActorID)).
INNER_JOIN(Film, Film.FilmID.EQ(FilmActor.FilmID)).
2019-06-24 18:22:55 +02:00
INNER_JOIN(Language, Language.LanguageID.EQ(Film.LanguageID)).
INNER_JOIN(FilmCategory, FilmCategory.FilmID.EQ(Film.FilmID)).
INNER_JOIN(Category, Category.CategoryID.EQ(FilmCategory.CategoryID)),
).WHERE(
2019-07-17 13:22:14 +02:00
Language.Name.EQ(String("English")).
AND(Category.Name.NOT_EQ(String("Action"))).
AND(Film.Length.GT(Int(180))),
2019-06-24 18:22:55 +02:00
).ORDER_BY(
Actor.ActorID.ASC(),
Film.FilmID.ASC(),
)
// Execute query and store result
2019-06-24 18:22:55 +02:00
var dest []struct {
model.Actor
2019-06-24 18:22:55 +02:00
Films []struct {
model.Film
2019-06-26 10:30:31 +02:00
Language model.Language
Categories []model.Category
2019-06-24 18:22:55 +02:00
}
}
err = stmt.Query(db, &dest)
panicOnError(err)
printStatementInfo(stmt)
jsonSave("./dest.json", dest)
2019-06-24 18:22:55 +02:00
2019-07-17 13:22:14 +02:00
// New Destination
2019-06-24 18:22:55 +02:00
var dest2 []struct {
model.Category
2019-06-26 10:30:31 +02:00
Films []model.Film
Actors []model.Actor
2019-06-24 18:22:55 +02:00
}
err = stmt.Query(db, &dest2)
panicOnError(err)
jsonSave("./dest2.json", dest2)
}
func jsonSave(path string, v interface{}) {
jsonText, _ := json.MarshalIndent(v, "", "\t")
err := os.WriteFile(path, jsonText, 0644)
2019-09-20 13:55:07 +02:00
panicOnError(err)
}
2019-08-08 12:02:32 +02:00
func printStatementInfo(stmt SelectStatement) {
query, args := stmt.Sql()
fmt.Println("Parameterized query: ")
2020-05-31 10:42:55 +02:00
fmt.Println("==============================")
fmt.Println(query)
fmt.Println("Arguments: ")
fmt.Println(args)
debugSQL := stmt.DebugSql()
fmt.Println("\n\nDebug sql: ")
2020-05-31 10:42:55 +02:00
fmt.Println("==============================")
fmt.Println(debugSQL)
2019-06-24 18:22:55 +02:00
}
func panicOnError(err error) {
if err != nil {
panic(err)
}
}