03.mysql配置和model
# 01.配置数据库连接
# 1.1 创建数据库
mysql> create database beegosc charset utf8;
1
# 1.2 配置mysql参数
mysqladmin="root"
mysqlpwd="chnsys@2016"
mysqldb="beegosc"
1
2
3
2
3
# 1.3 建立数据库链接
models/core.go
package models
import (
"github.com/astaxie/beego"
"github.com/jinzhu/gorm"
_ "github.com/jinzhu/gorm/dialects/mysql"
)
var DB *gorm.DB
var err error
func init() {
//和数据库建立连接
// DB, err = gorm.Open("mysql", "root:123456@/beego?charset=utf8&parseTime=True&loc=Local")
mysqladmin := beego.AppConfig.String("mysqladmin")
mysqlpwd := beego.AppConfig.String("mysqlpwd")
mysqldb := beego.AppConfig.String("mysqldb")
DB, err = gorm.Open("mysql", mysqladmin+":"+mysqlpwd+"@/"+mysqldb+"?charset=utf8&parseTime=True&loc=Local")
if err != nil {
beego.Error(err)
}
DB.LogMode(true)
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
# 1.4 关闭数据库链接
main.go
package main
import (
"beegogorm/models"
_ "beegogorm/routers"
"github.com/astaxie/beego"
)
func main() {
beego.Run()
defer models.DB.Close() //关闭数据库连接
}
1
2
3
4
5
6
7
8
9
10
11
2
3
4
5
6
7
8
9
10
11
# 02.定义数据库模型
# 2.1 models/user.go
package models
import (
_ "github.com/jinzhu/gorm"
)
type User struct {
Id int
Phone string
Password string
AddTime int
LastIp string
Email string
Status int
}
func (User) TableName() string {
return "user"
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
# 2.2 自动创建表
- 注意:GORM 的AutoMigrate函数,仅支持建表,不支持修改字段和删除字段,避免意外导致丢失数据。
- GORM更多用法 (opens new window)
models/core.go
func init() {
// 创建表
DB.CreateTable(&User{}) // 根据User结构体建表
DB.Set("gorm:table_options", "ENGINE=InnoDB").CreateTable(&User{}) // 设置表结构的存储引擎为InnoDB
}
1
2
3
4
5
2
3
4
5
上次更新: 2024/3/13 15:35:10