網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
1. 連接數(shù)據(jù)庫(kù)
要連接到數(shù)據(jù)庫(kù)首先要導(dǎo)入驅(qū)動(dòng)程序。例如
import _ "github.com/go-sql-driver/mysql"
為了方便記住導(dǎo)入路徑,GORM包裝了一些驅(qū)動(dòng)。
import _ "github.com/jinzhu/gorm/dialects/mysql" // import _ "github.com/jinzhu/gorm/dialects/postgres" // import _ "github.com/jinzhu/gorm/dialects/sqlite" // import _ "github.com/jinzhu/gorm/dialects/mssql"
1.1 MySQL
注:為了處理time.Time
,您需要包括parseTime
作為參數(shù)。 (更多支持的參數(shù))
import ( "github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/mysql" ) func main() { db, err := gorm.Open("mysql", "user:password@/dbname?charset=utf8&parseTime=True&loc=Local") defer db.Close() }
1.2 PostgreSQL
import ( "github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/postgres" ) func main() { db, err := gorm.Open("postgres", "host=myhost user=gorm dbname=gorm sslmode=disable password=mypassword") defer db.Close() }
1.3 Sqlite3
import ( "github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/sqlite" ) func main() { db, err := gorm.Open("sqlite3", "/tmp/gorm.db") defer db.Close() }
1.4 不支持的數(shù)據(jù)庫(kù)
GORM正式支持上述的數(shù)據(jù)庫(kù),如果您使用的是不受支持的數(shù)據(jù)庫(kù)請(qǐng)按照下面的連接編寫(xiě)對(duì)應(yīng)數(shù)據(jù)庫(kù)支持文件。?https://github.com/jinzhu/gorm/blob/master/dialect.go
2. 遷移
2.1. 自動(dòng)遷移
自動(dòng)遷移模式將保持更新到最新。
警告:自動(dòng)遷移僅僅會(huì)創(chuàng)建表,缺少列和索引,并且不會(huì)改變現(xiàn)有列的類(lèi)型或刪除未使用的列以保護(hù)數(shù)據(jù)。
db.AutoMigrate(&User{}) db.AutoMigrate(&User{}, &Product{}, &Order{}) // 創(chuàng)建表時(shí)添加表后綴 db.Set("gorm:table_options", "ENGINE=InnoDB").AutoMigrate(&User{})
2.2. 檢查表是否存在
// 檢查模型`User`表是否存在 db.HasTable(&User{}) // 檢查表`users`是否存在 db.HasTable("users")
2.3. 創(chuàng)建表
// 為模型`User`創(chuàng)建表 db.CreateTable(&User{}) // 創(chuàng)建表`users'時(shí)將“ENGINE = InnoDB”附加到SQL語(yǔ)句 db.Set("gorm:table_options", "ENGINE=InnoDB").CreateTable(&User{})
2.4. 刪除表
// 刪除模型`User`的表 db.DropTable(&User{}) // 刪除表`users` db.DropTable("users") // 刪除模型`User`的表和表`products` db.DropTableIfExists(&User{}, "products")
2.5. 修改列
修改列的類(lèi)型為給定值
// 修改模型`User`的description列的數(shù)據(jù)類(lèi)型為`text` db.Model(&User{}).ModifyColumn("description", "text")
2.6. 刪除列
// 刪除模型`User`的description列 db.Model(&User{}).DropColumn("description")
2.7. 添加外鍵
// 添加主鍵 // 1st param : 外鍵字段 // 2nd param : 外鍵表(字段) // 3rd param : ONDELETE // 4th param : ONUPDATE db.Model(&User{}).AddForeignKey("city_id", "cities(id)", "RESTRICT", "RESTRICT")
2.8. 索引
// 為`name`列添加索引`idx_user_name` db.Model(&User{}).AddIndex("idx_user_name", "name") // 為`name`, `age`列添加索引`idx_user_name_age` db.Model(&User{}).AddIndex("idx_user_name_age", "name", "age") // 添加唯一索引 db.Model(&User{}).AddUniqueIndex("idx_user_name", "name") // 為多列添加唯一索引 db.Model(&User{}).AddUniqueIndex("idx_user_name_age", "name", "age") // 刪除索引 db.Model(&User{}).RemoveIndex("idx_user_name")
原文鏈接:https://www.cnblogs.com/guyouyin123/p/14109856.html
相關(guān)推薦
- 2022-03-26 C語(yǔ)言中指針常量和常量指針的區(qū)別_C 語(yǔ)言
- 2022-07-19 Python?assert斷言聲明,遇到錯(cuò)誤則立即返回問(wèn)題_python
- 2021-12-13 linux系統(tǒng)AutoFs自動(dòng)掛載服務(wù)安裝配置_Linux
- 2022-09-16 Pandas?類(lèi)型轉(zhuǎn)換astype()的實(shí)現(xiàn)_python
- 2022-09-17 C++詳解PIMPL指向?qū)崿F(xiàn)的指針_C 語(yǔ)言
- 2022-04-28 Python中自定義函方法與參數(shù)具有默認(rèn)值的函數(shù)_python
- 2022-10-10 Go?語(yǔ)言前綴樹(shù)實(shí)現(xiàn)敏感詞檢測(cè)_Golang
- 2022-05-03 使用EF的Code?First模式操作數(shù)據(jù)庫(kù)_實(shí)用技巧
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門(mén)
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支