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

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

gorm 是否使用邏輯 OR 解釋結(jié)構(gòu)的內(nèi)容?

gorm 是否使用邏輯 OR 解釋結(jié)構(gòu)的內(nèi)容?

Go
料青山看我應(yīng)如是 2022-11-08 16:33:45
作為 SQL 新手,我正在編寫(xiě)一個(gè) API 中間件作為練習(xí),用于檢查某些標(biāo)頭中包含的信息是否與數(shù)據(jù)庫(kù)條目匹配(“基于令牌的身份驗(yàn)證”)。數(shù)據(jù)庫(kù)訪問(wèn)基于GORM.為此,我將我的 ORM 定義如下:type User struct {    ID       uint    UserName string    Token string}在我的中間件中,我檢索相關(guān)標(biāo)頭的內(nèi)容并以變量userHeader和tokenHeader. 它們應(yīng)該與數(shù)據(jù)庫(kù)匹配以進(jìn)行身份驗(yàn)證。該user表只有一個(gè)條目:select * from users // 1,admin,admintoken驗(yàn)證碼是    var auth User    res := db.Where(&User{UserName: userHeader, Token: tokenHeader}).Find(&auth)    if res.RowsAffected == 1 {        // authentication succeeded    }對(duì)此進(jìn)行測(cè)試時(shí),我得到以下兩個(gè)不正確的結(jié)果(其他組合是正確的):只有一個(gè)標(biāo)頭設(shè)置為正確的值(另一個(gè)不存在),身份驗(yàn)證成功(添加具有不正確值的另一個(gè)標(biāo)頭是可以的(=auth 失?。](méi)有設(shè)置標(biāo)題→身份驗(yàn)證通過(guò)我希望我的查詢意味著(在上述不正確結(jié)果的情況下) select * from users where users.user_name = 'admin' and users.token = '' select * from users where users.user_name = '' and users.token = ''并且此查詢?cè)诳刂婆_(tái)上是正確的,即產(chǎn)生零結(jié)果(針對(duì)數(shù)據(jù)庫(kù)運(yùn)行)。然而,ORM 似乎丟棄了不存在的標(biāo)題并假設(shè)它們很好(這至少是我的理解)我還嘗試通過(guò)鏈接Where子句db.Where(&User{UserName: userHeader}).Where(&User{Token: tokenHeader}).Find(&auth) 但結(jié)果是一樣的。正確的查詢應(yīng)該是什么?
查看完整描述

1 回答

?
慕萊塢森

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

gorm.io文檔對(duì)在條件句中使用結(jié)構(gòu)進(jìn)行了以下說(shuō)明Where

使用 struct 查詢時(shí),GORM只會(huì)查詢非零字段,這意味著如果您的字段的值為0,或其他零值'',false則不會(huì)用于構(gòu)建查詢條件...

建議的解決方案是:

要在查詢條件中包含零值,您可以使用映射,它將包含所有鍵值作為查詢條件...


因此,當(dāng)令牌頭或兩個(gè)頭都為空時(shí),但您仍希望將它們包含在WHERE生成的查詢的子句中,您需要使用 amap而不是 struct 作為Where方法的參數(shù)。

db.Where(map[string]interface{}{"user_name": userHeader, "token": tokenHeader}).Find(&auth)

您可以使用Debug()檢查生成的 SQL(它被打印到 stderr);如果您不確定您的代碼生成什么 SQL,請(qǐng)使用它


查看完整回答
反對(duì) 回復(fù) 2022-11-08
  • 1 回答
  • 0 關(guān)注
  • 229 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號(hào)

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