golang?gorm框架數(shù)據(jù)庫的連接操作示例
1. 連接數(shù)據(jù)庫
要連接到數(shù)據(jù)庫首先要導(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ù)庫
GORM正式支持上述的數(shù)據(jù)庫,如果您使用的是不受支持的數(shù)據(jù)庫請(qǐng)按照下面的連接編寫對(duì)應(yīng)數(shù)據(jù)庫支持文件。 https://github.com/jinzhu/gorm/blob/master/dialect.go
2. 遷移
2.1. 自動(dòng)遷移
自動(dòng)遷移模式將保持更新到最新。
警告:自動(dòng)遷移僅僅會(huì)創(chuàng)建表,缺少列和索引,并且不會(huì)改變現(xiàn)有列的類型或刪除未使用的列以保護(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語句 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. 修改列
修改列的類型為給定值
// 修改模型`User`的description列的數(shù)據(jù)類型為`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")
以上就是golang gorm框架數(shù)據(jù)庫操作示例的詳細(xì)內(nèi)容,更多關(guān)于golang gorm框架數(shù)據(jù)庫操作的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
golang 如何通過反射創(chuàng)建新對(duì)象
這篇文章主要介紹了golang 通過反射創(chuàng)建新對(duì)象的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-04-04golang 實(shí)現(xiàn)Location跳轉(zhuǎn)方式
這篇文章主要介紹了golang 實(shí)現(xiàn)Location跳轉(zhuǎn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-05-05Golang實(shí)現(xiàn)組合模式和裝飾模式實(shí)例詳解
這篇文章主要介紹了Golang實(shí)現(xiàn)組合模式和裝飾模式,本文介紹組合模式和裝飾模式,golang實(shí)現(xiàn)兩種模式有共同之處,但在具體應(yīng)用場(chǎng)景有差異。通過對(duì)比兩個(gè)模式,可以加深理解,需要的朋友可以參考下2022-11-11Sublime Text3安裝Go語言相關(guān)插件gosublime時(shí)搜不到gosublime的解決方法
本文主要介紹了Sublime Text3安裝Go語言相關(guān)插件gosublime時(shí)搜不到gosublime的解決方法,具有一定的參考價(jià)值,感興趣的可以了解一下2022-01-01gin框架Context如何獲取Get?Query?Param函數(shù)數(shù)據(jù)
這篇文章主要為大家介紹了gin框架Context?Get?Query?Param函數(shù)獲取數(shù)據(jù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03基于Go語言實(shí)現(xiàn)的簡(jiǎn)易api網(wǎng)關(guān)的示例代碼
本文主要介紹了基于Go語言實(shí)現(xiàn)的簡(jiǎn)易api網(wǎng)關(guān),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-12-12