Quick start example redirect json to files.
This commit is contained in:
parent
1ae76d5efd
commit
f841f6f8f0
2 changed files with 58 additions and 22 deletions
10
examples/quick-start/README.md
Normal file
10
examples/quick-start/README.md
Normal file
|
|
@ -0,0 +1,10 @@
|
||||||
|
|
||||||
|
# Quick start example
|
||||||
|
|
||||||
|
This package contains sample usage for Jet framework.
|
||||||
|
|
||||||
|
Jet generated files of interest are in ./gen folder.
|
||||||
|
|
||||||
|
quick-start.go contains code explained at [README.md](../../README.md#quick-start),
|
||||||
|
with difference of redirecting json output to files(dest.json and dest2.json) rather then to a
|
||||||
|
standard output.
|
||||||
|
|
@ -5,6 +5,7 @@ import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
_ "github.com/lib/pq"
|
_ "github.com/lib/pq"
|
||||||
|
"io/ioutil"
|
||||||
|
|
||||||
// dot import so go code would resemble as much as native SQL
|
// dot import so go code would resemble as much as native SQL
|
||||||
// dot import is not mandatory
|
// dot import is not mandatory
|
||||||
|
|
@ -12,15 +13,26 @@ import (
|
||||||
. "github.com/go-jet/jet/examples/quick-start/.gen/jetdb/dvds/table"
|
. "github.com/go-jet/jet/examples/quick-start/.gen/jetdb/dvds/table"
|
||||||
|
|
||||||
"github.com/go-jet/jet/examples/quick-start/.gen/jetdb/dvds/model"
|
"github.com/go-jet/jet/examples/quick-start/.gen/jetdb/dvds/model"
|
||||||
"github.com/go-jet/jet/tests/dbconfig"
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
Host = "localhost"
|
||||||
|
Port = 5432
|
||||||
|
User = "jet"
|
||||||
|
Password = "jet"
|
||||||
|
DBName = "jetdb"
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
|
||||||
db, err := sql.Open("postgres", dbconfig.ConnectString)
|
// Connect to database
|
||||||
|
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)
|
||||||
panicOnError(err)
|
panicOnError(err)
|
||||||
defer db.Close()
|
defer db.Close()
|
||||||
|
|
||||||
|
// Write query
|
||||||
stmt := SELECT(
|
stmt := SELECT(
|
||||||
Actor.ActorID, Actor.FirstName, Actor.LastName, Actor.LastUpdate,
|
Actor.ActorID, Actor.FirstName, Actor.LastName, Actor.LastUpdate,
|
||||||
Film.AllColumns,
|
Film.AllColumns,
|
||||||
|
|
@ -42,24 +54,13 @@ func main() {
|
||||||
Film.FilmID.ASC(),
|
Film.FilmID.ASC(),
|
||||||
)
|
)
|
||||||
|
|
||||||
query, args, err := stmt.Sql()
|
// Execute query and store result
|
||||||
panicOnError(err)
|
|
||||||
|
|
||||||
fmt.Println("Parameterized query: ")
|
|
||||||
fmt.Println(query)
|
|
||||||
fmt.Println("Arguments: ")
|
|
||||||
fmt.Println(args)
|
|
||||||
|
|
||||||
debugSQL, err := stmt.DebugSql()
|
|
||||||
panicOnError(err)
|
|
||||||
|
|
||||||
fmt.Println("Debug sql: ")
|
|
||||||
fmt.Println(debugSQL)
|
|
||||||
|
|
||||||
var dest []struct {
|
var dest []struct {
|
||||||
model.Actor
|
model.Actor
|
||||||
|
|
||||||
Films []struct {
|
Films []struct {
|
||||||
model.Film
|
model.Film
|
||||||
|
|
||||||
Language model.Language
|
Language model.Language
|
||||||
Categories []model.Category
|
Categories []model.Category
|
||||||
}
|
}
|
||||||
|
|
@ -68,9 +69,8 @@ func main() {
|
||||||
err = stmt.Query(db, &dest)
|
err = stmt.Query(db, &dest)
|
||||||
panicOnError(err)
|
panicOnError(err)
|
||||||
|
|
||||||
fmt.Println("dest to json: ")
|
printStatementInfo(stmt)
|
||||||
jsonText, _ := json.MarshalIndent(dest, "", "\t")
|
jsonSave("./dest.json", dest)
|
||||||
fmt.Println(string(jsonText))
|
|
||||||
|
|
||||||
// New Destination
|
// New Destination
|
||||||
|
|
||||||
|
|
@ -84,9 +84,35 @@ func main() {
|
||||||
err = stmt.Query(db, &dest2)
|
err = stmt.Query(db, &dest2)
|
||||||
panicOnError(err)
|
panicOnError(err)
|
||||||
|
|
||||||
fmt.Println("dest2 to json: ")
|
jsonSave("./dest2.json", dest2)
|
||||||
jsonText, _ = json.MarshalIndent(dest2, "", "\t")
|
}
|
||||||
fmt.Println(string(jsonText))
|
|
||||||
|
func jsonSave(path string, v interface{}) {
|
||||||
|
jsonText, _ := json.MarshalIndent(v, "", "\t")
|
||||||
|
|
||||||
|
err := ioutil.WriteFile(path, jsonText, 0644)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func printStatementInfo(stmt Statement) {
|
||||||
|
query, args, err := stmt.Sql()
|
||||||
|
panicOnError(err)
|
||||||
|
|
||||||
|
fmt.Println("Parameterized query: ")
|
||||||
|
fmt.Println(query)
|
||||||
|
fmt.Println("Arguments: ")
|
||||||
|
fmt.Println(args)
|
||||||
|
|
||||||
|
debugSQL, err := stmt.DebugSql()
|
||||||
|
panicOnError(err)
|
||||||
|
|
||||||
|
fmt.Println("\n\n==============================")
|
||||||
|
|
||||||
|
fmt.Println("\n\nDebug sql: ")
|
||||||
|
fmt.Println(debugSQL)
|
||||||
}
|
}
|
||||||
|
|
||||||
func panicOnError(err error) {
|
func panicOnError(err error) {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue