douzao2590 2018-01-16 03:28
浏览 340
已采纳

如何在Gorm中正确执行部分更新?

I have some sort of virtual file system. List of folders, each folder contains files, and ACL. So structure looks like this:

type Model struct {
    ID        uint       `gorm:"primary_key" json:"id"`
}

type User struct {
    Model
    Name string
}

type Folder struct {
    Model
    Name string
}

type File struct {
    Model
    Name string
    FolderID      uint
    Folder        Folder
    Acl           []User `json:"acl" gorm:"many2many:file_acl"`
} 

It comes from frontend as full fledged JSON. It gets demarshalled. What happens next when I call Save(&file) it correctly stores File, creates record inside file_acl.

Also it updates Folder and Users.

Here comes my question - how to skip those dependent updates but retain autogenerated queries to update/insert into file_acl table?

  • 写回答

2条回答 默认 最新

  • dongshi6844 2018-03-29 18:27
    关注

    To prevent cascade updates you should use association_autoupdate option.

    Db.Set("gorm:association_autoupdate", false).Save(&file)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 宇视监控服务器无法登录
  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥15 DruidDataSource一直closing
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据