前言
gorm 是 golang 語(yǔ)言編寫(xiě)的開(kāi)源庫(kù),支持全功能 orm。官方支持的數(shù)據(jù)庫(kù)類(lèi)型有: MySQL, PostgreSQL, SQlite, SQL Server。 本篇博文整理一下 gorm 操作 mysql 一些方法
官網(wǎng)中文文檔:https://gorm.io/zh_CN/docs/index.html
連接 mysql 服務(wù)器
方式一
// 參考 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{})
方式二
db, err := gorm.Open(mysql.New(mysql.Config{
DSN: "gorm:gorm@tcp(127.0.0.1:3306)/gorm?charset=utf8&parseTime=True&loc=Local", // DSN data source name
DefaultStringSize: 256, // string 類(lèi)型字段的默認(rèn)長(zhǎng)度
DisableDatetimePrecision: true, // 禁用 datetime 精度,MySQL 5.6 之前的數(shù)據(jù)庫(kù)不支持
DontSupportRenameIndex: true, // 重命名索引時(shí)采用刪除并新建的方式,MySQL 5.7 之前的數(shù)據(jù)庫(kù)和 MariaDB 不支持重命名索引
DontSupportRenameColumn: true, // 用 `change` 重命名列,MySQL 8 之前的數(shù)據(jù)庫(kù)和 MariaDB 不支持重命名列
SkipInitializeWithVersion: false, // 根據(jù)當(dāng)前 MySQL 版本自動(dòng)配置
}), &gorm.Config{})
gorm 基本操作
gorm 模型定義
gorm 進(jìn)階操作
后記
未完,待續(xù)......