MySQL
With GORM
Single Instance
mysql:
items:
main:
conn_max_lifetime: 1h
dsn: root:123456@tcp(localhost:3306)/sample?charset=utf8mb4&parseTime=True&loc=Local
max_idle_conns: 1
max_open_conns: 10
Parameters
conn_max_lifetime
: maximum lifetime of a connection.dsn
: dsn string.max_idle_conns
: maximum number of idle connections.max_open_conns
: maximum number of open connections.
package main
import (
"fmt"
"github.com/langwan/langgo"
"github.com/langwan/langgo/components/mysql"
)
func main() {
langgo.Run(&mysql.Instance{})
var i int64
mysql.Main().Raw("SELECT 1").Scan(&i)
fmt.Println(i)
}
Multi Instances
mysql:
items:
main:
conn_max_lifetime: 1h
dsn: root:123456@tcp(localhost:3306)/sample?charset=utf8mb4&parseTime=True&loc=Local
max_idle_conns: 1
max_open_conns: 10
slave:
conn_max_lifetime: 1h
dsn: slave:123456@tcp(localhost:3306)/sample?charset=utf8mb4&parseTime=True&loc=Local
max_idle_conns: 1
max_open_conns: 10
package main
import (
"fmt"
"github.com/langwan/langgo"
"github.com/langwan/langgo/components/mysql"
)
func main() {
langgo.Run(&mysql.Instance{})
var i int64
mysql.Main().Raw("SELECT 1").Scan(&i)
fmt.Println(i)
mysql.Get("slave").Raw("SELECT 2").Scan(&i)
fmt.Println(i)
}
Last updated