V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
jonathanchoo
V2EX  ›  Go 编程语言

求教 Beego 的 ORM 里的 InsertOrUpdate 方法怎么更新指定的列

  •  
  •   jonathanchoo · 2020-11-03 14:06:15 +08:00 · 2663 次点击
    这是一个创建于 1499 天前的主题,其中的信息可能已经有所发展或是发生改变。

    不管是

    Oconnect.InsertOrUpdate(nc, fmt.Sprintf("%s=%s+%s", "col_name", "col_name", "mock_value"))
    

    还是

    Oconnect.InsertOrUpdate(nc, fmt.Sprintf("%s=%s", "col_name", "mock_value"))
    

    依然没用啊。。

    求教

    5 条回复    2022-07-05 14:14:01 +08:00
    harlen
        1
    harlen  
       2020-11-03 16:12:16 +08:00
    InsertOrUpdate 的意思是, 如果要插入的行已经存在,那就更新这条数据。 不能用来更新其他行的数据哦。
    jonathanchoo
        2
    jonathanchoo  
    OP
       2020-11-03 16:32:23 +08:00
    @harlen
    就是更新已存在的啊,我不想更新 created_at 的话,怎么做呢
    ninjashixuan
        3
    ninjashixuan  
       2020-11-03 17:02:31 +08:00
    如果是单纯想更新已存在的 update 不就行了,为什么要 InsertOrUpdate?
    harlen
        4
    harlen  
       2020-11-03 17:06:19 +08:00
    nc 中不存在 created_at 就不会更新了,如果还是更新了,你应该检查一下是生成的 sql 更新了这个字段,还是数据库的字段设置了在更新的时间更新
    jonathanchoo
        5
    jonathanchoo  
    OP
       2022-07-05 14:14:01 +08:00
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3123 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 04:51 · PVG 12:51 · LAX 20:51 · JFK 23:51
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.