iris/_examples/database/orm/reform/main.go
Gerasimos (Makis) Maropoulos acf058b006
add database/orm/reform example
2020-08-01 03:46:51 +03:00

51 lines
1006 B
Go

package main
/*
$ go get gopkg.in/reform.v1/reform
$ go generate ./models
$ go run .
Read more at: https://github.com/go-reform/reform
*/
import (
"database/sql"
"myapp/controllers"
"github.com/kataras/iris/v12"
"github.com/kataras/iris/v12/mvc"
_ "github.com/mattn/go-sqlite3"
"gopkg.in/reform.v1"
"gopkg.in/reform.v1/dialects/sqlite3"
)
func main() {
app := iris.New()
app.Logger().SetLevel("debug")
sqlDB, err := sql.Open("sqlite3", "./myapp.db")
if err != nil {
panic(err)
}
defer sqlDB.Close()
sqlStmt := `
drop table people;
create table people (id integer not null primary key, name text, email text, created_at datetime not null, updated_at datetime null);
delete from people;
`
_, err = sqlDB.Exec(sqlStmt)
if err != nil {
panic(err)
}
db := reform.NewDB(sqlDB, sqlite3.Dialect, reform.NewPrintfLogger(app.Logger().Debugf))
mvcApp := mvc.New(app.Party("/persons"))
mvcApp.Register(db)
mvcApp.Handle(new(controllers.PersonController))
app.Listen(":8080")
}