字典數(shù)據(jù)是什么?
這里說(shuō)了字典不是軟件工程中說(shuō)的數(shù)據(jù)字典。
字典數(shù)據(jù):用于動(dòng)態(tài)設(shè)置某對(duì)象的屬性是屬于在一個(gè)可列舉的數(shù)據(jù)范圍內(nèi)的某一類(lèi)型數(shù)據(jù),使用字典類(lèi)型作為該類(lèi)別屬性的唯一標(biāo)識(shí)
如:用戶(hù)類(lèi)型:學(xué)生,老師,家長(zhǎng),校長(zhǎng)等
有什么作用?
字典數(shù)據(jù)由兩個(gè)表組成:字典類(lèi)型表 dict_type,字典類(lèi)型數(shù)據(jù)表 dict_data
這個(gè)數(shù)據(jù)相當(dāng)于java中的枚舉類(lèi),可以被使用于前端的數(shù)據(jù)展示,下拉框數(shù)據(jù)集使用。
沒(méi)有數(shù)據(jù)字典時(shí)業(yè)務(wù)操作方法:
定義學(xué)生枚舉類(lèi),在代碼中使用枚舉類(lèi)的key進(jìn)行數(shù)據(jù)保存,在查詢(xún)數(shù)據(jù)后,轉(zhuǎn)換key對(duì)應(yīng)的中文名稱(chēng)label標(biāo)簽返回給前端。
缺點(diǎn):如新增用戶(hù)類(lèi)型,修改學(xué)生類(lèi)型對(duì)應(yīng)中文名稱(chēng)時(shí),需要修改代碼。
使用字典時(shí)業(yè)務(wù)操作方法。
后端業(yè)務(wù)數(shù)據(jù)存儲(chǔ)的是字典類(lèi)型的key值,即label標(biāo)簽表示學(xué)生類(lèi)型對(duì)應(yīng)的key值 student,
新增數(shù)據(jù)時(shí)前端通過(guò)下拉菜單獲取學(xué)生類(lèi)型某一個(gè)類(lèi)型key進(jìn)行新增,查詢(xún)數(shù)據(jù)時(shí)根據(jù)字典數(shù)據(jù)表的用戶(hù)類(lèi)型作為下拉框查詢(xún)條件選擇。
優(yōu)點(diǎn):當(dāng)key為student的數(shù)據(jù)中文名稱(chēng)發(fā)生改變時(shí),不需要后端進(jìn)行代碼修改。
如新增用戶(hù)時(shí),設(shè)置用戶(hù)的類(lèi)型,下拉框的數(shù)據(jù)可以從數(shù)據(jù)庫(kù)獲取數(shù)據(jù),不用前端關(guān)心數(shù)據(jù)集的內(nèi)容,
在業(yè)務(wù)中使用
不使用緩存的方式使用字典數(shù)據(jù):
業(yè)務(wù)中使用方式,返回用戶(hù)列表數(shù)據(jù),將用戶(hù)類(lèi)型的字典數(shù)據(jù)從數(shù)據(jù)庫(kù)中查詢(xún)出來(lái),然后進(jìn)行轉(zhuǎn)換。
在前端查詢(xún)數(shù)據(jù)時(shí),前端查詢(xún)用戶(hù)類(lèi)型的下拉數(shù)據(jù)集,作為條件,傳類(lèi)型key值作為查詢(xún)條件查詢(xún)數(shù)據(jù)。
與緩存搭配使用字典數(shù)據(jù)。
自己控制數(shù)據(jù)緩存。靈活性高:Ehcache,Redis等內(nèi)存緩存框架進(jìn)行處理。
如果是單機(jī)項(xiàng)目。可以使用內(nèi)存緩存。
緩存的使用方式有多種:
如使用Mybatis自帶的一級(jí)緩存,二級(jí)緩存。但如果使用的是不同的SqlSession進(jìn)行數(shù)據(jù)查詢(xún),這不會(huì)用到一級(jí)緩存。
單機(jī)項(xiàng)目最好還是使用內(nèi)存緩存框架,如Ehcache,用Map來(lái)存儲(chǔ)所有字典數(shù)據(jù)。在更新字典數(shù)據(jù)后,直接整個(gè)更新緩存數(shù)據(jù)。
1
2
3
4
5
6
7
|
{ "字典類(lèi)型" : [ { "key" : "label" } ] } |
如果是分布式(雖然沒(méi)實(shí)際用過(guò)):可以使用redis這種外置的非關(guān)系型數(shù)據(jù)庫(kù)存儲(chǔ)緩存數(shù)據(jù)。即一個(gè)類(lèi)型一個(gè)key來(lái)存儲(chǔ)數(shù)據(jù)。如
RedisUtils.put( "dict:type_user_type" ) RedisUtils.get( "dict:type_user_type" )
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:https://www.cnblogs.com/gne-hwz/p/13644625.html