gpt4 book ai didi

go - 有什么方法可以摆脱 GORM 中的自动列蛇案例重命名?

转载 作者:行者123 更新时间:2023-12-01 22:11:08 24 4
gpt4 key购买 nike

我计划将 GORM 与现有数据库一起使用,因此我正在为它创建一些模型。但是,我遇到了一个问题——GORM 自动将所有列重命名为小写蛇形。我真的不需要它,因为我使用的数据库并没有真正使用这样的名称。我发现,我可以使用标签

`gorm:"column_name:`

为了防止我的专栏被重命名。然而,它对我来说似乎并不是一个可行的解决方案,因为我有一堆带有大量列的模型。有什么方法可以从 GORM 关闭这个“重命名”策略,或者自动为我的所有模型添加标签吗?

我的模型看起来像这样:

type FOOD_DES struct {
NDB_NO string `gorm:"primary_key"`
FdGrp_Cd FD_GROUP
Long_Desc string
Shrt_Desc string
ComName string
ManufacName string
Survey string
Ref_desc string
Refuse float32
SciName string
N_Factor float32
Pro_Factor float32
Fat_Factor float32
CHO_Factor float32
}

最佳答案

来自 doc :

GORM allows users to change the naming conventions by overriding thedefault NamingStrategy which need to implements interface Namer

type Namer interface {
TableName(table string) string
ColumnName(table, column string) string
JoinTableName(table string) string
RelationshipFKName(Relationship) string
CheckerName(table, column string) string
IndexName(table, column string) string
}

所以只需实现接口(interface) Namer。

在旧版本中,你可以这样做 ( Ref )

gorm.AddNamingStrategy(&gorm.NamingStrategy{
DB: func(name string) string {
return name
},
Table: func(name string) string {
return name
},
Column: func(name string) string {
return name
},
})

关于go - 有什么方法可以摆脱 GORM 中的自动列蛇案例重命名?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63603901/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com