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

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

對(duì)于有多種狀態(tài)值的字段,其狀態(tài)值該如何管理

對(duì)于有多種狀態(tài)值的字段,其狀態(tài)值該如何管理

紅糖糍粑 2019-07-06 23:06:39
問題:對(duì)于有多種狀態(tài)值的字段,其狀態(tài)值該如何管理。舉例:比如用戶的狀態(tài)(user_status)包括:1(已注冊(cè)未激活),2(已激活),3(已鎖定),4(已注銷)在數(shù)據(jù)庫里,會(huì)保存其對(duì)應(yīng)的索引值(key)1,2,3,4,那么就需要有一個(gè)字典表,保存其對(duì)應(yīng)的value(已注冊(cè)未激活,已激活,已鎖定,已注銷)在一次前后臺(tái)交互的過程中,除了返回給前端的用戶信息外,還會(huì)把字典信息一并返回給前端,方便前端處理。但是考慮下面一種情景:用戶注冊(cè)接口,新注冊(cè)的用戶默認(rèn)狀態(tài)為,已注冊(cè),未激活。user.setUserStatus(1);但是,如果后臺(tái)數(shù)據(jù)庫的索引值變化了,已注冊(cè)未激活的索引值變?yōu)榱?,那么這個(gè)時(shí)候,就需要修改代碼邏輯。如果涉及多段類似代碼的修改,會(huì)很容易造成錯(cuò)誤。請(qǐng)問:如何設(shè)計(jì)后臺(tái)代碼對(duì)這些字典信息的管理以及如何設(shè)計(jì)數(shù)據(jù)庫字典表?
查看完整描述

2 回答

?
有只小跳蛙

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

首先這個(gè)數(shù)字是自定義的,已注冊(cè)未激活等于1還是等于5是沒有意義的,數(shù)據(jù)庫層面來說這兩個(gè)沒有太大關(guān)系.如果你的系統(tǒng)過于復(fù)雜,你可以做一個(gè)字典表(表里面id就是你的status,status_name就是你的已注冊(cè)未激活),然后設(shè)計(jì)一個(gè)用戶字典樹關(guān)聯(lián)表,真的需求出現(xiàn)的時(shí)候,你可以通過一個(gè)sql去批量更新.不過話說回來,大部分改數(shù)字的情況都是需求不合理或者設(shè)計(jì)不合理導(dǎo)致的.
                            
查看完整回答
反對(duì) 回復(fù) 2019-07-06
?
白衣非少年

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

可以考慮使用枚舉將各個(gè)狀態(tài)和值相關(guān)聯(lián),使用時(shí)就可以u(píng)ser.setUserStatus(UserStatus.LOCKED)之類的方式來盡可能的減少代碼改動(dòng)的范圍。eg.
publicenumUserStatus{
LOCKED(3);//othersimilar
publicfinalBytecode;
privateUserStatus(intcode){
this.code=(byte)code;
}
}
不過這樣做時(shí)需要注意的是數(shù)據(jù)庫中已存的用戶狀態(tài)需要通過sql語句手動(dòng)更新。(雖然這種需求本身就不是很合理)
                            
查看完整回答
反對(duì) 回復(fù) 2019-07-06
  • 2 回答
  • 0 關(guān)注
  • 478 瀏覽
慕課專欄
更多

添加回答

舉報(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)