type User struct { Name string`gorm:"index"` Name2 string`gorm:"index:idx_name,unique"` Name3 string`gorm:"index:,sort:desc,collate:utf8,type:btree,length:10,where:name3 != 'jinzhu'"` Name4 string`gorm:"uniqueIndex"` Age int64`gorm:"index:,class:FULLTEXT,comment:hello \\, world,where:age > 10"` Age2 int64`gorm:"index:,expression:ABS(age)"` }
// MySQL 选项 type User struct { Name string`gorm:"index:,class:FULLTEXT,option:WITH PARSER ngram INVISIBLE"` }
// PostgreSQL 选项 type User struct { Name string`gorm:"index:,option:CONCURRENTLY"` }
唯一索引
uniqueIndex 标签的作用与 index 类似,它等效于 index:,unique
1 2 3 4
type User struct { Name1 string`gorm:"uniqueIndex"` Name2 string`gorm:"uniqueIndex:idx_name,sort:desc"` }
复合索引
两个字段使用同一个索引名将创建复合索引,例如:
1 2 3 4 5
// create composite index `idx_member` with columns `name`, `number` type User struct { Name string`gorm:"index:idx_member"` Number string`gorm:"index:idx_member"` }