目录
- 1. 连接数据库
- 1.1 MySQL
- 1.2 PostgreSQL
- 1.3 Sqlite3
- 1.4 不支持的数据库
- 2. 迁移
- 2.1. 自动迁移
- 2.2. 检查表是否存在
- 2.3. 创建表
- 2.4. 删除表
- 2.5. 修改列
- 2.6. 删除列
- 2.7. 添加外键
- 2.8. 索引
1. 连接数据库
要连接到数据库首先要导入驱动程序。例如 - import _ "github.com/go-sql-driver/mysql"
复制代码为了方便记住导入路径,GORM包装了一些驱动。 - 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
注:为了处理 ,您需要包括 作为参数。 (更多支持的参数) - 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 不支持的数据库
GORM正式支持上述的数据库,如果您使用的是不受支持的数据库请按照下面的连接编写对应数据库支持文件。 https://github.com/jinzhu/gorm/blob/master/dialect.go
2. 迁移
2.1. 自动迁移
自动迁移模式将保持更新到最新。
警告:自动迁移 仅仅会创建表,缺少列和索引,并且不会改变现有列的类型或删除未使用的列以保护数据。 - db.AutoMigrate(&User{})
- db.AutoMigrate(&User{}, &Product{}, &Order{})
- // 创建表时添加表后缀
- db.Set("gorm:table_options", "ENGINE=InnoDB").AutoMigrate(&User{})
复制代码 2.2. 检查表是否存在
- // 检查模型`User`表是否存在
- db.HasTable(&User{})
- // 检查表`users`是否存在
- db.HasTable("users")
复制代码 2.3. 创建表
- // 为模型`User`创建表
- db.CreateTable(&User{})
- // 创建表`users'时将“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列的数据类型为`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框架数据库操作示例的详细内容,更多关于golang gorm框架数据库操作的资料请关注晓枫资讯其它相关文章!
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |