fix
zhangqian
2023-12-08 2dea693b0d78246e0db41e8e2daaf6ad9cc3ed8c
fix
1个文件已修改
30 ■■■■ 已修改文件
model/model.go 30 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
model/model.go
@@ -9,7 +9,7 @@
)
type CommonModel struct {
    ID        uint   `gorm:"primary_key;autoIncrement:false" json:"-"`
    ID        uint   `gorm:"primary_key" json:"-"`
    IDStr     string `json:"ID" gorm:"-"`
    CreatedAt time.Time
    UpdatedAt time.Time
@@ -20,21 +20,35 @@
    if c.ID == 0 {
        id := snowflake.GenerateID()
        if id < 0 {
            // 处理 ID 为负数的情况(可选)
            id = snowflake.GenerateID()
        }
        c.ID = uint(id)
    }
}
func (c CommonModel) UnmarshalJSON(b []byte) (err error) {
    id, err := strconv.ParseUint(c.IDStr, 10, 64)
    if err != nil {
func (c *CommonModel) UnmarshalJSON(b []byte) error {
    var data map[string]interface{}
    if err := json.Unmarshal(b, &data); err != nil {
        return err
    }
    c.ID = uint(id)
    return
    if idStr, ok := data["ID"].(string); ok {
        id, err := strconv.ParseUint(idStr, 10, 64)
        if err != nil {
            return err
        }
        c.ID = uint(id)
        c.IDStr = idStr
    }
    return nil
}
func (c CommonModel) MarshalJSON() ([]byte, error) {
    c.IDStr = strconv.FormatUint(uint64(c.ID), 10)
func (c *CommonModel) MarshalJSON() ([]byte, error) {
    if c.ID != 0 && c.IDStr == "" {
        c.IDStr = strconv.FormatUint(uint64(c.ID), 10)
    }
    return json.Marshal(c)
}