Quick start example redirect json to files.

This commit is contained in:
go-jet 2019-07-20 18:53:12 +02:00
parent 1ae76d5efd
commit f841f6f8f0
2 changed files with 58 additions and 22 deletions

View 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.

View file

@ -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) {