第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

使用嵌套對(duì)象更新記錄,從而產(chǎn)生重復(fù)鍵錯(cuò)誤

使用嵌套對(duì)象更新記錄,從而產(chǎn)生重復(fù)鍵錯(cuò)誤

Go
動(dòng)漫人物 2022-08-09 20:21:00
我需要更新用戶配置文件,我正在獲取整個(gè)配置文件,允許用戶編輯他想要的內(nèi)容,然后再次將整個(gè)配置文件發(fā)送到服務(wù)器以保存更新的任何值,但它不起作用。User {   Address {       Country {             // fields        },    // fields   },  Settings {     // fields   },  username: string,   email: string,}為了避免復(fù)雜化,我想發(fā)送整個(gè)記錄,保存所有內(nèi)容,更新任何內(nèi)容或?yàn)槲锤碌淖侄卧俅伪4媾f值。我試過這個(gè):// Update User datafunc (r *RepositoryUserCrud) Update(uid int, user models.User) (int, error) {    var err error// 1, did not work, getting  Error 1062: Duplicate entry for email err = r.db.Debug().Model(&models.User{}).Where("id = ?", unit(uid)).Updates(user).Error// 2, did not work, getting  Error 1062: Duplicate entry for email err = r.db.Save(&user).Error;// 3, I tried to skip the duplicate key error by using {onConflict: DoNothing}err = r.db.Debug().Clauses(r.db.Model(&models.User{})                  .Where("id = ?", uint(uid)))                  .OnConflict{DoNothing: true}                  .Updates(user)}關(guān)于如何做到這一點(diǎn)的任何建議?如果深度嵌套對(duì)象中發(fā)生了更改,如何將更改應(yīng)用于其表?還是我應(yīng)該手動(dòng)執(zhí)行此操作?
查看完整描述

1 回答

?
www說

TA貢獻(xiàn)1775條經(jīng)驗(yàn) 獲得超8個(gè)贊

事實(shí)證明,電子郵件字段是主鍵,并且我沒有將ID作為更新記錄的一部分傳遞,因此它基本上是嘗試使用相同的電子郵件創(chuàng)建新記錄。

所以這個(gè)代碼工作,但要確保提供記錄本身。ID

err = r.db.Debug().Model(&models.User{}).Where("id = ?", unit(uid)).Updates(user).Error

我還需要手動(dòng)更新其他表中的鏈接行。


查看完整回答
反對(duì) 回復(fù) 2022-08-09
  • 1 回答
  • 0 關(guān)注
  • 91 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)