> ORM框架操作數據庫都需要預先定義模型
[TOC]
## 模型定義
~~~
//在這里User類型可以代表mysql user表
type User struct {
ID uint `gorm:"primary_key"`
Username string `gorm:"column:username"`
Password string `gorm:"column:password"`
CreateTime int64 `gorm:"column:createtime"`
}
//設置User模型對應的表名
func (u User) TableName() string {
//綁定MYSQL表名為user
return "user"
}
~~~
## gorm新增記錄
~~~
//定義一個用戶,并初始化數據
u := User{
Username: "tizi365",
Password: "123456",
CreateTime: time.Now().Unix(),
}
//插入一條用戶數據
//下面代碼會自動生成SQL語句:INSERT INTO `users` (`username`,`password`,`createtime`) VALUES ('tizi365','123456','1540824823')
db.Create(u)
//一般項目中我們會類似下面的寫法,通過Error對象檢測,插入數據有沒有成功,如果沒有錯誤那就是數據寫入成功了。
if err := db.Create(&u).Error; err != nil {
fmt.Println("插入失敗", err)
return
}
fmt.Println("自增ID:", u.ID, "用戶昵稱:", u.Username)
~~~
- 基礎知識
- 開發環境
- 包名規則
- 包初始化 (init)
- 基礎數據類型
- 基礎類型轉換
- 格式化輸出
- go指針
- 流程控制語句
- 函數定義
- 匿名函數
- 數組和切片
- map集合
- 結構體
- Interface接口
- 日期處理
- 數學計算
- 正則表達式
- 協程 (并發處理)
- channel
- waitgroup
- mutex (鎖機制)
- websocket
- protobuf
- Redis
- 錯誤處理
- 打包程序
- NSQ消息隊列
- 單元測試
- beego
- 安裝入門
- Gin
- 快速入門
- 路由與控制器
- 處理請求參數
- 表單驗證
- 處理響應結果
- 渲染HTML模版
- 訪問靜態文件
- Gin中間件
- Cookie處理
- Session處理
- Gin上傳文件
- swagger
- pprof性能測試
- GORM
- 入門教程
- 模型定義
- 數據庫連接
- 插入數據
- 查詢數據
- 更新數據
- 刪除數據
- 事務處理
- 關聯查詢
- 屬于 (BELONG TO)
- 一對一 (Has One)
- 一對多 (Has Many)
- 多對多 (Many to Many)
- 預加載 (Preloading)
- 錯誤處理
- 第三方常用插件
- viper 讀取配置文件
- zap 高性能日志
- Nginx代理配置
- Goland 快捷鍵