婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > golang常用庫之操作數據庫的orm框架-gorm基本使用詳解

golang常用庫之操作數據庫的orm框架-gorm基本使用詳解

熱門標簽:智能電銷機器人營銷 濮陽自動外呼系統代理 廣東語音外呼系統供應商 地圖標注測試 賺地圖標注的錢犯法嗎 烏魯木齊人工電銷機器人系統 長沙ai機器人電銷 福州鐵通自動外呼系統 澳門防封電銷卡

golang常用庫:gorilla/mux-http路由庫使用
golang常用庫:配置文件解析庫-viper使用
golang常用庫:操作數據庫的orm框架-gorm基本使用

一:字段映射-模型定義

gorm中通常用struct來映射字段. gorm教程中叫模型定義

比如我們定義一個模型Model:

type User struct {
	gorm.Model
	UserId int64 `gorm:"index"` //設置一個普通的索引,沒有設置索引名,gorm會自動命名
	Birtheday time.Time
 Age  int  `gorm:"column:age"`//column:一個tag,可以設置列名稱
 Name string `gorm:"size:255;index:idx_name_add_id"`//size:設置長度大小,index:設置索引,這個就取了一個索引名
	Num  int  `gorm:"AUTO_INCREMENT"`
 Email string `gorm:"type:varchar(100);unique_index"`//type:定義字段類型和大小
	AddressID sql.NullInt64 `gorm:"index:idx_name_add_id"`
	IgnoreMe int  `gorm:"_"`
	Description string `gorm:"size:2019;comment:'用戶描述字段'"`//comment:字段注釋
	Status string `gorm:"type:enum('published', 'pending', 'deleted');default:'pending'"`
}

上面的gorm.Model 定義如下:

type Model struct {
 ID uint `gorm:"primary_key"`//primary_key:設置主鍵
 CreatedAt time.Time
 UpdatedAt time.Time
 DeletedAt *time.Time
}

當然我們也可以不用gorm.Model,自己定義一個差不多的類型

如果你用ID,系統會自動設為表的主鍵,當然我們可以自己定義主鍵:
比如:

// 使用`AnimalID`作為主鍵
type Animal struct {
 AnimalID int64 `gorm:"primary_key"`
 Name string
 Age int64
}

參考:https://gorm.io/zh_CN/docs/conventions.html

二:創建表

直接看下面的例子:createtable.go

package main

import (
	"database/sql"
	"fmt"
	"github.com/jinzhu/gorm"
	_ "github.com/jinzhu/gorm/dialects/mysql"
	"time"
)

type User struct {
	gorm.Model
	UserId int64 `gorm:"index"`
	Birtheday time.Time
	Age  int  `gorm:"column:age"`
	Name string `gorm:"size:255;index:idx_name_add_id"`
	Num  int  `gorm:"AUTO_INCREMENT"`
	Email string `gorm:"type:varchar(100);unique_index"`
	AddressID sql.NullInt64 `gorm:"index:idx_name_add_id"`
	IgnoreMe int  `gorm:"_"`
	Description string `gorm:"size:2019;comment:'用戶描述字段'"`
	Status string `gorm:"type:enum('published', 'pending', 'deleted');default:'pending'"`
}

//設置表名,默認是結構體的名的復數形式
func (User) TableName() string {
	return "VIP_USER"
}

func main() {
	db, err := gorm.Open("mysql", "root:root@/gormdemo?charset=utf8parseTime=Trueloc=Local")
	if err != nil {
		fmt.Println("connect db err: ", err)
	}
	defer db.Close()

	if db.HasTable(User{}) { //判斷表是否存在
		db.AutoMigrate(User{}) //存在就自動適配表,也就說原先沒字段的就增加字段
	} else {
		db.CreateTable(User{}) //不存在就創建新表
	}
}

上面的gorm.Open()操作,如果想指定主機話,就需要加上括號 ()
例如:

user:password@(localhost)/dbname?charset=utf8parseTime=Trueloc=Local

上面的程序中,先新建了一個數據庫名叫gormdemo,然后運行:go run createtable.go , 成功運行后,數據庫就會出現一張名為 vip_user 的表。

三:增刪改查

新建一個gormdemo的數據庫,然后執行下面的sql語句,就會建立一個animals的表,里面還有一些測試數據

CREATE TABLE `animals` (
 `id` bigint(20) NOT NULL AUTO_INCREMENT,
 `name` varchar(255) DEFAULT 'galeone',
 `age` int(10) unsigned DEFAULT '0',
 PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of animals
-- ----------------------------
INSERT INTO `animals` VALUES ('1', 'demo-test', '20');
INSERT INTO `animals` VALUES ('2', 'galeone', '30');
INSERT INTO `animals` VALUES ('3', 'demotest', '30');
INSERT INTO `animals` VALUES ('4', 'jim', '90');
INSERT INTO `animals` VALUES ('5', 'jimmy', '10');
INSERT INTO `animals` VALUES ('6', 'jim', '23');
INSERT INTO `animals` VALUES ('7', 'test3', '27');

增加

例子:create.go

package main

import (
	"fmt"

	"github.com/jinzhu/gorm"
	_ "github.com/jinzhu/gorm/dialects/mysql"
)

type Animal struct {
	ID int64
	Name string
	Age int64
}

func main() {
	db, err := gorm.Open("mysql", "root:root@/gormdemo?charset=utf8parseTime=trueloc=Local")
	if err != nil {
		fmt.Println("connect db error: ", err)
	}
	defer db.Close()

	animal := Animal{Name: "demo-test", Age: 20}
	db.Create(animal)
}

說明:上面的這個例子,自己在mysql中創建一個animals的數據表,字段為id,name,age

查找

select.go

package main

import (
	"fmt"

	"github.com/jinzhu/gorm"

	_ "github.com/jinzhu/gorm/dialects/mysql"
)

type Animal struct {
	ID int64
	Name string
	Age int64
}

//https://gorm.io/zh_CN/docs/query.html
func main() {
	db, err := gorm.Open("mysql", "root:root@/gormdemo?charset=utf8parseTime=trueloc=Local")
	if err != nil {
		fmt.Println("connect db error: ", err)
	}
	defer db.Close()

	//根據逐漸查詢第一條記錄
	var animal Animal
	db.First(animal)
	fmt.Println(animal)

	//根據逐漸查詢最后一條記錄
	var animal2 Animal
	db.Last(animal2)
	fmt.Println(animal2)

	//指定某條記錄(僅當主鍵為整型時可用)
	var animal3 Animal
	db.First(animal3, 2)
	fmt.Println(animal3)

	//where條件

	//符合條件的第一條記錄
	var animal4 Animal
	db.Where("name = ?", "demotest2").First(animal4)
	fmt.Println("where : ", animal4, animal4.ID, animal4.Name, animal4.Age)

	//符合條件的所有記錄
	var animals5 []Animal
	db.Where("name = ?", "galeone").Find(animals5)
	fmt.Println(animals5)
	for k, v := range animals5 {
		fmt.Println("k:", k, "ID:", v.ID, "Name:", v.Name, "Age:", v.Age)
	}

	//IN
	var animals6 []Animal
	db.Where("name IN (?)", []string{"demo-test", "demotest2"}).Find(animals6)
	fmt.Println(animals6)

	//LIKE
	var animals7 []Animal
	db.Where("name like ?", "%jim%").Find(animals7)
	fmt.Println(animals7)

	//AND
	var animals8 []Animal
	db.Where("name = ? AND age >= ?", "jim", "24").Find(animals8)
	fmt.Println(animals8)

	//總數
	var count int
	var animals9 []Animal
	db.Where("name = ?", "galeone").Or("name = ?", "jim").Find(animals9).Count(count)
	fmt.Println(animals9)
	fmt.Println(count)

	//Scan, 原生查詢
	var animals10 []Animal
	db.Raw("SELECT id, name, age From Animals WHERE name = ? AND age = ? ", "galeone", "30").Scan(animals10)
	fmt.Println("Scan: ", animals10)

	//原生查詢,select all
	var animals11 []Animal
	rows, _ := db.Raw("SELECT id,name FROM Animals").Rows()
	//注意:上面的 select id,name 后面不能寫成 * 代替,不然出來的結果都是默認0值
	//像這樣結果: ALL: [{0 0} {0 0} {0 0} {0 0} {0 0} {0 0} {0 0}]
	//Scan 后面是什么字段,select 后面就緊跟什么字段
	for rows.Next() {
		var result Animal
		rows.Scan(result.ID, result.Name)
		animals11 = append(animals11, result)
	}
	fmt.Println("ALL: ", animals11)
	//output:ALL: [{1 demo-test 0} {2 galeone 0} {3 demotest2 0} {4 galeone 0} {5 galeone 0} {6 jim 0} {7 jimmy 0}]

	//select 查詢
	var animal12 Animal
	db.Select("name,age").Find(animal12) //只查詢name,age字段,相當于select name,age from user
	fmt.Println("select: ", animal12)
	// db.Select([]string{"name", "age"}).Find(animal12)
	// fmt.Println("select2: ", animal12)
}

更新

update.go

package main

import (
	"fmt"

	"github.com/jinzhu/gorm"
	_ "github.com/jinzhu/gorm/dialects/mysql"
)

type Animal struct {
	ID int64
	Name string
	Age int64
}

func main() {
	db, err := gorm.Open("mysql", "root:root@/gormdemo?charset=utf8parseTime=trueloc=Local")
	if err != nil {
		fmt.Println("connect db error: ", err)
	}
	defer db.Close()

	///根據一個條件更新
	//根據條件更新字段值,
	//后面加Debug(),運行時,可以打印出sql
	db.Debug().Model(Animal{}).Where("id = ? ", 4).Update("name", "jimupdate")
	//UPDATE `animals` SET `name` = 'jimupdate' WHERE (id = 4)

	//另外一種寫法: 根據條件更新
	var animal Animal
	animal = Animal{ID: 3}
	db.Debug().Model(animal).Update("name", "demotest2update")
	// db.Debug().Model(animal).Update("name", "demotest2update") // 這種寫法也可以
	//UPDATE `animals` SET `name` = 'demotest2update' WHERE `animals`.`id` = 3

	/// 多個條件更新
	db.Model(Animal{}).Where("id = ? AND age = ?", 4, 45).Update("name", "jimupdate3")
	//UPDATE `animals` SET `name` = 'jimupdate2' WHERE (id = 4 AND age = 45)

	/// 更新多個值
	db.Debug().Model(Animal{}).Where("id = ?", 4).Update(Animal{Name: "jim", Age: 90})
	// UPDATE `animals` SET `age` = 90, `name` = 'jim' WHERE (id = 4)

	animal2 := Animal{ID: 5}
	db.Debug().Model(animal2).Update(map[string]interface{}{"name": "jimm", "age": 100})
	//UPDATE `animals` SET `age` = 100, `name` = 'jimm' WHERE `animals`.`id` = 5
}

刪除

delete.go

package main

import (
	"fmt"

	"github.com/jinzhu/gorm"
	_ "github.com/jinzhu/gorm/dialects/mysql"
)

type Animal struct {
	ID int64
	Name string
	Age int64
}

func main() {
	db, err := gorm.Open("mysql", "root:root@/gormdemo?charset=utf8parseTime=trueloc=Local")
	if err != nil {
		fmt.Println("connect db error: ", err)
	}
	defer db.Close()

	db.Debug().Where("id = ?", 13).Delete(Animal{})
	// DELETE FROM `animals` WHERE (id = 13)

	db.Debug().Delete(Animal{}, "id = ? AND age = ?", 14, 10)
	//DELETE FROM `animals` WHERE (id = 14 AND age = 10)

}

四:Debug

在db后面直接加上 Debug(), 比如delete.go 里面的例子

五:參考

https://gorm.io/zh_CN/

到此這篇關于golang常用庫之操作數據庫的orm框架-gorm基本使用詳解的文章就介紹到這了,更多相關golang gorm使用內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • golang Gorm與數據庫完整性約束詳解
  • golang gorm 結構體的表字段缺省值設置方式
  • golang gorm 計算字段和獲取sum()值的實現
  • golang gorm多條件篩選查詢操作
  • gorm golang 并發連接數據庫報錯的解決方法
  • golang gorm中格式化時間問題詳解
  • Golang 使用gorm添加數據庫排他鎖,for update

標簽:西雙版納 調研邀請 廣西 慶陽 阿克蘇 德州 貴陽 太原

巨人網絡通訊聲明:本文標題《golang常用庫之操作數據庫的orm框架-gorm基本使用詳解》,本文關鍵詞  golang,常用,庫之,操作,數據庫,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang常用庫之操作數據庫的orm框架-gorm基本使用詳解》相關的同類信息!
  • 本頁收集關于golang常用庫之操作數據庫的orm框架-gorm基本使用詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美高清dvd| 欧美视频中文字幕| 91精品国产色综合久久不卡蜜臀| 国产精品人妖ts系列视频| 一本大道av一区二区在线播放| 国产日韩欧美高清在线| 亚洲精品写真福利| 色av成人天堂桃色av| 色丁香久综合在线久综合在线观看| 一区二区三区欧美视频| 一本久久精品一区二区| 国产一区二区久久| 亚洲人一二三区| 精品电影一区二区三区| 亚洲天堂av老司机| 久久久精品国产免费观看同学| 久久成人18免费观看| 亚洲va国产va欧美va观看| 综合在线观看色| 欧美日韩国产美女| 日本一区二区三区电影| 欧美日韩高清在线播放| 92精品国产成人观看免费| 国产精品久久久久久久久快鸭 | 欧美激情一区二区在线| 精品区一区二区| 日韩欧美电影一区| 国产日韩成人精品| 成人免费视频caoporn| 日韩av不卡一区二区| 久久久综合视频| 日本韩国欧美在线| 久久久99久久| 色婷婷精品久久二区二区蜜臂av | 久久久久久久综合日本| 国产精品亚洲一区二区三区妖精| 中文字幕亚洲综合久久菠萝蜜| 日本韩国欧美三级| 国内成+人亚洲+欧美+综合在线 | 国产女同性恋一区二区| 亚洲国产成人在线| 欧美96一区二区免费视频| 99视频一区二区三区| 色拍拍在线精品视频8848| 欧美日韩精品高清| 色8久久精品久久久久久蜜| 一区二区三区影院| 欧美岛国在线观看| 一区二区三区欧美在线观看| 丝袜亚洲另类丝袜在线| 亚洲日本乱码在线观看| 亚洲中国最大av网站| 欧美成人乱码一区二区三区| 亚洲一区二区三区视频在线| 亚洲色图一区二区三区| 国产精品久久久久9999吃药| 天天综合日日夜夜精品| 欧美探花视频资源| 亚洲欧洲99久久| 亚洲男人天堂av| 波多野结衣一区二区三区| 一区二区三区日韩欧美精品| 日韩一区国产二区欧美三区| 欧美性大战久久久久久久| 国产日产精品1区| 一区二区高清在线| 色综合中文字幕国产| 国产精品视频观看| 五月婷婷久久丁香| 国产自产高清不卡| 欧美大片一区二区三区| 亚洲小少妇裸体bbw| 久久亚区不卡日本| 欧美女孩性生活视频| 国产一区二区三区四区五区入口 | 51精品久久久久久久蜜臀| 国产老女人精品毛片久久| 91麻豆精品国产91久久久久久| 日韩伦理电影网| 欧美日韩一级二级| 国产麻豆日韩欧美久久| 国产乱人伦精品一区二区在线观看 | 不卡av免费在线观看| 亚洲午夜久久久久久久久久久| 欧美日韩一区中文字幕| 国产精品91xxx| 国产精品色在线观看| 粉嫩av一区二区三区| 欧美人牲a欧美精品| 中文成人综合网| 国产日韩欧美在线一区| 一区二区三区在线免费播放| 91免费视频大全| 日韩女同互慰一区二区| 亚洲妇熟xx妇色黄| 精品久久久久久综合日本欧美| 国产精品福利一区二区| 久久国内精品视频| 免费在线一区观看| 一区二区三区在线免费视频| 91精品国产综合久久久久| 国产性色一区二区| 国产成人日日夜夜| 成人激情午夜影院| 日本亚洲视频在线| 国产精品区一区二区三区| 一区二区三区丝袜| 天使萌一区二区三区免费观看| 欧美一区二区三区四区视频 | 一区二区在线看| 一区二区三区资源| 亚洲国产精品久久人人爱| 色婷婷综合五月| 国产成人综合亚洲网站| 欧美一区二区福利在线| 中文字幕在线不卡视频| 亚洲国产另类av| 韩国女主播一区| 精品久久久久久久久久久久久久久| 精品亚洲免费视频| 最近中文字幕一区二区三区| 亚洲三级在线免费| 欧美成人一区二区| 精品国精品自拍自在线| 亚洲va国产天堂va久久en| 亚洲一区二区精品久久av| 欧美国产欧美综合| 欧美tickling挠脚心丨vk| 久久综合精品国产一区二区三区| 国产精品亚洲专一区二区三区| 成人开心网精品视频| 亚洲少妇最新在线视频| av亚洲精华国产精华精华| 亚洲激情图片一区| 欧美性受xxxx| 一本色道**综合亚洲精品蜜桃冫| 欧美在线观看视频一区二区三区 | 国产在线不卡一卡二卡三卡四卡| 国产传媒欧美日韩成人| 久久久久国产免费免费| 国产在线精品一区在线观看麻豆| 欧美国产1区2区| 亚洲日本护士毛茸茸| 91麻豆文化传媒在线观看| 欧美国产日韩a欧美在线观看| 久久黄色级2电影| 国产日韩亚洲欧美综合| 欧美激情艳妇裸体舞| 精品伦理精品一区| 亚洲成a人v欧美综合天堂| 91小视频免费看| 日韩高清不卡一区二区| 尤物av一区二区| 国产尤物一区二区| 久久se精品一区精品二区| 中文字幕在线不卡| 日韩三级精品电影久久久 | 国产精华液一区二区三区| 亚洲精品一二三四区| 欧美日韩一区 二区 三区 久久精品| 国产精品久久久久久久久免费相片 | 亚洲美女在线国产| 欧美男生操女生| 国产精品亲子乱子伦xxxx裸| 亚洲电影欧美电影有声小说| 蜜臀av性久久久久av蜜臀妖精| 成人午夜大片免费观看| 国产精品福利影院| 国产成人亚洲综合a∨婷婷| 精品一区二区三区久久| 宅男在线国产精品| jlzzjlzz欧美大全| 粉嫩aⅴ一区二区三区四区五区| 精品福利av导航| 欧美精选在线播放| 国产成人在线观看免费网站| 精品粉嫩aⅴ一区二区三区四区| 香蕉加勒比综合久久| 欧美亚男人的天堂| 欧美成人激情免费网| 激情久久久久久久久久久久久久久久| 日韩情涩欧美日韩视频| 欧美性xxxxxxxx| 成人精品一区二区三区四区| 国产主播一区二区| 国产精品欧美精品| 欧美日韩国产精选| 日韩欧美成人一区| av高清不卡在线| 国产精品自在欧美一区| 午夜久久久久久久久久一区二区| 日本不卡视频在线| 亚洲精品免费视频| 日本不卡的三区四区五区| 中文字幕在线一区二区三区| 天天色天天操综合| 成人在线综合网| 伦理电影国产精品| 精品福利在线导航| 欧美不卡视频一区|