初識(shí)-gorm

安裝
go get -u gorm.io/gorm
go get -u gorm.io/driver/sqlite
gorm.Model模型
type Model struct {
  ID        uint           `gorm:"primaryKey"`
  CreatedAt time.Time
  UpdatedAt time.Time
  DeletedAt gorm.DeletedAt `gorm:"index"`
}
  • gorm約定默認(rèn)將ID作為主鍵
  • 我們可以將Model模型嵌入結(jié)構(gòu)體中
type user struct {
    gorm.Model
    Name string
}
字段標(biāo)簽
  • 聲明 model 時(shí),tag 是可選的,GORM 支持以下 tag: tag 名大小寫不敏感忌卤,但建議使用 camelCase 風(fēng)格
type user struct {
    ID   uint `gorm:"primaryKey"`
    Name string
}
image.png
連接到mysql數(shù)據(jù)庫
import (
  "gorm.io/driver/mysql"
  "gorm.io/gorm"
)

func main() {
  // 參考 https://github.com/go-sql-driver/mysql#dsn-data-source-name 獲取詳情
  dsn := "user:pass@tcp(127.0.0.1:3306)/dbname?charset=utf8mb4&parseTime=True&loc=Local"
  db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
}

遷移

  • AutoMigrate()用于自動(dòng)遷移您的 schema,保持您的 schema 是最新的惨好。
db.AutoMigrate(&User{})
  • db.Migrator().CurrentDatabase() //返回當(dāng)前使用的數(shù)據(jù)庫名
其他遷移
  • GORM 的 AutoMigrate 適用于大多數(shù)的遷移,如果您需要更加個(gè)性化的遷移工具 随闺,GORM 提供的一個(gè)通用數(shù)據(jù)庫接口可能對(duì)您有幫助。
// returns `*sql.DB`
db.DB()
創(chuàng)建記錄
package main

import (
    "fmt"
    "gorm.io/driver/mysql"
    "gorm.io/gorm"
)

type user struct {
    ID   uint `gorm:"primaryKey"`
    Name string
    Age  uint
}

func main() {

    dsn := "user:pass@tcp(127.0.0.1:3306)/dbname?charset=utf8mb4&parseTime=True&loc=Local"

    db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
    if err != nil {
        fmt.Println("err", err)
    }
    db.AutoMigrate(&user{})
    u := user{
        Name: "mac",
        Age:  18,
    }
    result := db.Create(&u)
    fmt.Println(u.ID)                //返回ID
    fmt.Println(result.Error)        //返回error
    fmt.Println(result.RowsAffected) //返回插入記錄的條數(shù)

}
用指定字段插入
db.Select("Name").Create(&u)    //只插入Name字段
db.Omit("Name", ).Create(&u)    //插入除Name以外的其他字段
批量插入
var users = []User{{Name: "person1"}, {Name: "person2"}, {Name: "person3"}}
db.Create(&users)
使用map插入
    db.Model(&User{}).Create(map[string]interface{}{
        "Name": "person", "Age": 18,
    })
    
    // batch insert from `[]map[string]interface{}{}`
    db.Model(&User{}).Create([]map[string]interface{}{
        {"Name": "person1", "Age": 18},
        {"Name": "person2", "Age": 20},
    })
查詢
// 獲取第一條記錄(主鍵升序)
db.First(&user)
// SELECT * FROM users ORDER BY id LIMIT 1;

// 獲取一條記錄蔓腐,沒有指定排序字段
db.Take(&user)
// SELECT * FROM users LIMIT 1;

// 獲取最后一條記錄(主鍵降序)
db.Last(&user)
// SELECT * FROM users ORDER BY id DESC LIMIT 1;
//獲取所有記錄
db.Find(&user)
//SELECT * FROM users 
用主鍵檢索
db.First(&user, 10)
// SELECT * FROM users WHERE id = 10;

db.First(&user, "10")
// SELECT * FROM users WHERE id = 10;

db.Find(&users, []int{1,2,3})
// SELECT * FROM users WHERE id IN (1,2,3);

更新

保存所有字段
db.First(&user)

user.Name = "person"
user.Age = 18
db.Save(&user)
保存非零字段
db.Where("id=?",1).Update("name","jerry")

刪除

db.Delete(&user)
db.Where("name=?", "jerry").Delete(&user{})
根據(jù)主鍵刪除
db.Delete(&User{}, 10)
// DELETE FROM users WHERE id = 10;

db.Delete(&User{}, "10")
// DELETE FROM users WHERE id = 10;

db.Delete(&users, []int{1,2,3})
// DELETE FROM users WHERE id IN (1,2,3);

執(zhí)行原生SQL

raw()+scan()
type Result struct {
  ID   int
  Name string
  Age  int
}

var result Result
db.Raw("SELECT id, name, age FROM users WHERE name = ?", 3).Scan(&result)

db.Raw("SELECT id, name, age FROM users WHERE name = ?", 3).Scan(&result)

var age int
db.Raw("SELECT SUM(age) FROM users WHERE role = ?", "admin").Scan(&age)

var users []User
db.Raw("UPDATE users SET name = ? WHERE age = ? RETURNING id, name", "person", 20).Scan(&users)

Exec() 原生SQL

db.Exec("DROP TABLE users")
db.Exec("UPDATE orders SET shipped_at = ? WHERE id IN ?", time.Now(), []int64{1, 2, 3})

// Exec with SQL Expression
db.Exec("UPDATE users SET money = ? WHERE name = ?", gorm.Expr("money * ? + ?", 10000, 1), "person")
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末矩乐,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子回论,更是在濱河造成了極大的恐慌散罕,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件傀蓉,死亡現(xiàn)場(chǎng)離奇詭異欧漱,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)葬燎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,347評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門误甚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來缚甩,“玉大人,你說我怎么就攤上這事窑邦∩猛” “怎么了?”我有些...
    開封第一講書人閱讀 157,435評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵冈钦,是天一觀的道長(zhǎng)郊丛。 經(jīng)常有香客問我,道長(zhǎng)瞧筛,這世上最難降的妖魔是什么厉熟? 我笑而不...
    開封第一講書人閱讀 56,509評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮较幌,結(jié)果婚禮上庆猫,老公的妹妹穿的比我還像新娘。我一直安慰自己绅络,他們只是感情好月培,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,611評(píng)論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著恩急,像睡著了一般杉畜。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上衷恭,一...
    開封第一講書人閱讀 49,837評(píng)論 1 290
  • 那天此叠,我揣著相機(jī)與錄音,去河邊找鬼随珠。 笑死灭袁,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的窗看。 我是一名探鬼主播茸歧,決...
    沈念sama閱讀 38,987評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼显沈!你這毒婦竟也來了软瞎?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,730評(píng)論 0 267
  • 序言:老撾萬榮一對(duì)情侶失蹤拉讯,失蹤者是張志新(化名)和其女友劉穎涤浇,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體魔慷,經(jīng)...
    沈念sama閱讀 44,194評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡只锭,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,525評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了院尔。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蜻展。...
    茶點(diǎn)故事閱讀 38,664評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡喉誊,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出铺呵,到底是詐尸還是另有隱情裹驰,我是刑警寧澤,帶...
    沈念sama閱讀 34,334評(píng)論 4 330
  • 正文 年R本政府宣布片挂,位于F島的核電站幻林,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏音念。R本人自食惡果不足惜沪饺,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,944評(píng)論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望闷愤。 院中可真熱鬧整葡,春花似錦、人聲如沸讥脐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,764評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽旬渠。三九已至俱萍,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間告丢,已是汗流浹背枪蘑。 一陣腳步聲響...
    開封第一講書人閱讀 31,997評(píng)論 1 266
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留岖免,地道東北人岳颇。 一個(gè)月前我還...
    沈念sama閱讀 46,389評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像颅湘,于是被迫代替她去往敵國(guó)和親话侧。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,554評(píng)論 2 349

推薦閱讀更多精彩內(nèi)容

  • GORM中文文檔讀者可以直接看文檔栅炒,本文只是從文檔記錄個(gè)人常用的一些操作掂摔。 1.安裝 2.使用 官方一個(gè)快速入門的...
    10xjzheng閱讀 9,897評(píng)論 1 1
  • 胖sir :接著,給你一個(gè)餡餅兒 兵長(zhǎng) : 來嘞<独释移!一篇來自O(shè)RM的整理筆記... 1 什么是ORM?為什么要?O...
    阿兵云原生閱讀 158評(píng)論 0 1
  • 簡(jiǎn)介 定義模型 ModelStruct獲取表名StructFieldRelationship更多 Scope模型解...
    刷漆貓咪閱讀 861評(píng)論 0 0
  • 關(guān)于Mongodb的全面總結(jié) MongoDB的內(nèi)部構(gòu)造《MongoDB The Definitive Guide》...
    中v中閱讀 31,912評(píng)論 2 89
  • [TOC] 說明 請(qǐng)先閱讀官方文檔[http://gorm.book.jasperxu.com/]寥殖,由于官方文檔對(duì)...
    小晚不晚閱讀 1,702評(píng)論 0 0