Skip to content

Latest commit

 

History

History
91 lines (71 loc) · 2.07 KB

README.md

File metadata and controls

91 lines (71 loc) · 2.07 KB

modules/gorm

Gorm module

Activation

module.gorm = github.com/revel/modules/orm/gorm

Drivers

  • sqlite3
  • postgres
  • mysql

Configuration file

# Database config
db.autoinit=true # default=true
db.driver=sqlite3 # mysql, postgres, sqlite3
db.host=/tmp/app.db  # Use db.host /tmp/app.db is your driver is sqlite
#db.port=dbport # when the port is not used the default of each driver
#db.user=dbuser
#db.name=dbname
#db.password=dbpassword
#db.singulartable=false # default=false

Database Configuration Parameters Extended Information

  • autoinit: The Db is initialized from the app.conf if db.autoinit=true.
  • singulartable: By default all tables created based on a struct are pluralized. For Example: a type User struct {} becomes table users in the database , by setting singulartable to true, User's default table name will be user. Note table names set with TableName won't be affected by this setting. You can also change the created table names by setting gorm.DefaultTableNameHandler on AppStartup or func init() see here for more details

Example usage with transactions

package controllers

import (
    "github.com/revel/revel"
    gormc "github.com/revel/modules/orm/gorm/app/controllers"
)

type App struct {
    gormc.TxnController
}

type Toy struct {
    Name string
}

func (c App) Index() revel.Result {
    c.Txn.LogMode(true)
    c.Txn.AutoMigrate(&Toy{})
    c.Txn.Save(&Toy{Name: "Fidget spinner"})

    return c.Render()
}

Example usage without transactions

package controllers

import (
    "github.com/revel/revel"
    gormc "github.com/revel/modules/orm/gorm/app/controllers"
)

type App struct {
    gormc.Controller
}

type Toy struct {
    Name string
}

func (c App) Index() revel.Result {
    c.DB.LogMode(true)
    c.DB.AutoMigrate(&Toy{})
    c.DB.Save(&Toy{Name: "Fidget spinner"})

    return c.Render()
}