表结构
指定表名
如果不想用GORM默认的数据库表格命名方式,可以自己指定表名。一种方式是给Model绑定TableName方法指定。
type Stu struct {Id intName stringAge intSex string}// TableName 指定表名func (Stu) TableName() string {return "student"}
查询时指定表明
另一种指定表名的方式是使用Table方法。
db.Table("student").First(&student)
代码示例
package mainimport ("fmt"_ "github.com/go-sql-driver/mysql""gorm.io/driver/mysql""gorm.io/gorm""gorm.io/gorm/schema")type Stu struct {Id intName stringAge intSex string}// TableName 指定表名func (Stu) TableName() string {return "student"}var db *gorm.DBvar err errorfunc init() {//dsn格式 user:pass@tcp(ip:port)/dbname?charset=utf8mb4&parseTime=True&loc=Localdsn := "root:password@tcp(127.0.0.1:3306)/test?charset=utf8mb4&parseTime=True&loc=Local"db, err = gorm.Open(mysql.Open(dsn), &gorm.Config{NamingStrategy: schema.NamingStrategy{TablePrefix: "", // 表前缀SingularTable: true, // 禁用表名复数}})if err != nil {panic(err)}}func main() {var student Studb.First(&student) // 取第一条到studentfmt.Println(student)}
参考资料
https://gorm.io/docs/connecting_to_the_database.html
来源地址:https://blog.csdn.net/lilongsy/article/details/127783649