2019-06-24 18:22:55 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"database/sql"
|
|
|
|
|
"encoding/json"
|
|
|
|
|
"fmt"
|
2019-07-13 13:17:28 +02:00
|
|
|
_ "github.com/lib/pq"
|
2019-07-20 18:53:12 +02:00
|
|
|
"io/ioutil"
|
2019-06-24 18:22:55 +02:00
|
|
|
|
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
|
|
|
|
|
. "github.com/go-jet/jet/examples/quick-start/.gen/jetdb/dvds/table"
|
2019-08-03 14:10:47 +02:00
|
|
|
. "github.com/go-jet/jet/postgres"
|
2019-06-24 18:22:55 +02:00
|
|
|
|
2019-07-13 13:17:28 +02:00
|
|
|
"github.com/go-jet/jet/examples/quick-start/.gen/jetdb/dvds/model"
|
2019-07-20 18:53:12 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
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() {
|
2019-07-20 18:53:12 +02:00
|
|
|
// 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)
|
2019-07-20 18:53:12 +02:00
|
|
|
|
|
|
|
|
db, err := sql.Open("postgres", connectString)
|
2019-06-24 18:22:55 +02:00
|
|
|
panicOnError(err)
|
|
|
|
|
defer db.Close()
|
|
|
|
|
|
2019-07-20 18:53:12 +02:00
|
|
|
// 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,
|
2019-06-24 18:22:55 +02:00
|
|
|
Language.AllColumns,
|
|
|
|
|
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(),
|
|
|
|
|
)
|
|
|
|
|
|
2019-07-20 18:53:12 +02:00
|
|
|
// Execute query and store result
|
2019-06-24 18:22:55 +02:00
|
|
|
var dest []struct {
|
|
|
|
|
model.Actor
|
2019-07-20 18:53:12 +02:00
|
|
|
|
2019-06-24 18:22:55 +02:00
|
|
|
Films []struct {
|
|
|
|
|
model.Film
|
2019-07-20 18:53:12 +02:00
|
|
|
|
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)
|
|
|
|
|
|
2019-07-20 18:53:12 +02:00
|
|
|
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)
|
|
|
|
|
|
2019-07-20 18:53:12 +02:00
|
|
|
jsonSave("./dest2.json", dest2)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func jsonSave(path string, v interface{}) {
|
|
|
|
|
jsonText, _ := json.MarshalIndent(v, "", "\t")
|
|
|
|
|
|
|
|
|
|
err := ioutil.WriteFile(path, jsonText, 0644)
|
|
|
|
|
|
2019-09-20 13:55:07 +02:00
|
|
|
panicOnError(err)
|
2019-07-20 18:53:12 +02:00
|
|
|
}
|
|
|
|
|
|
2019-08-08 12:02:32 +02:00
|
|
|
func printStatementInfo(stmt SelectStatement) {
|
2019-08-13 13:57:26 +02:00
|
|
|
query, args := stmt.Sql()
|
2019-07-20 18:53:12 +02:00
|
|
|
|
|
|
|
|
fmt.Println("Parameterized query: ")
|
2020-05-31 10:42:55 +02:00
|
|
|
fmt.Println("==============================")
|
2019-07-20 18:53:12 +02:00
|
|
|
fmt.Println(query)
|
|
|
|
|
fmt.Println("Arguments: ")
|
|
|
|
|
fmt.Println(args)
|
|
|
|
|
|
2019-08-13 13:57:26 +02:00
|
|
|
debugSQL := stmt.DebugSql()
|
2019-07-20 18:53:12 +02:00
|
|
|
|
|
|
|
|
fmt.Println("\n\nDebug sql: ")
|
2020-05-31 10:42:55 +02:00
|
|
|
fmt.Println("==============================")
|
2019-07-20 18:53:12 +02:00
|
|
|
fmt.Println(debugSQL)
|
2019-06-24 18:22:55 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func panicOnError(err error) {
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
}
|