2024-06-03|閱讀時間 ‧ 約 24 分鐘

[Go][ORM]Gorm

Gorm是一款性能極好的ORM,且友善,因此可以明顯的提高開發效率。

特點

  • 全功能ORM
  • 支持連結
  • 支援Hook
  • 支持預先載入
  • 支援交易
  • 支持復合主鍵
  • 支持SQL生成器
  • 支援資料庫自動遷移
  • 支援自訂日誌
  • 可擴充性
  • 所有功能都被測試覆蓋


安裝

go get -u gorm.io/gorm


使用

資料庫連接

package main

import (
_ "github.com/go-sql-driver/mysql"
"gorm.io/gorm"
)

func main() {
db, err := gorm.Open("mysql", "root:root@(127.0.0.1:3306)/db1?" +
"charset=utf8mb4&parseTime=True&loc=Local")
if err!= nil{
panic(err)
}
defer db.Close()
db.DB().SetMaxIdleConns(10)
db.DB().SetMaxOpenConns(100)
}

SetMaxIdleConns:閒置時最大連接數。

SetMaxOpenConns:最大連接數。


建表

定義好結構後,用db.AutoMigrate(),就會自動創建。


插入

GormUser := GormUser{
Phone: "0987654321",
Name: "xxx",
Password: md5Password("333333"), //使用者密碼
}
db.Save(&GormUser) //儲存到資料庫


刪除

var GormUser = new(GormUser)
db.Where("phone = ?", "0987654321").Delete(&GormUser)


查詢

var GormUser = new(GormUser)
db.Where("phone = ?", "0987654321").Find(&GormUser)
fmt.Println(GormUser)


更新

var GormUser = new(GormUser)
err:=db.Model(&GormUser).Where("phone = ?", "0987654321").
Update("phone", "0987666666").Error
if err !=nil {
//......
}


交易處理

tx := db.Begin()
GormUser := GormUser{
Phone: "0987654321",
Name: "xxx",
Password: md5Password("333333"), //使用者密碼
}
if err := tx.Create(&GormUser).Error; err != nil {
//復原
tx.Rollback()
fmt.Println(err)
}
db.First(&GormUser, "phone = ?", "0987654321")
//提交​
tx.Commit()


日誌

db.LogMode(true)
db.SetLogger(log.New(os.Stdout, "\r\n", 0))


分享至
成為作者繼續創作的動力吧!
© 2024 vocus All rights reserved.