当前位置: 首页>編程日記>正文

mysql 字典表设计_字典表设计

mysql 字典表设计_字典表设计

为什么字典表?

存在问题:

某些变量在多个地方使用,而且一般是固定的,但是随着系统升级和后期变化,可能需要改变,如果这些变量写死在代码里面将会变得难以维护,所以要将其从代码中抽离出来。

一般的业务系统客户端与用户交互的时候都会使用下拉框组件,对于某些比较固定的值的下拉组件的数据来源一般都是比较固定的一类数值。

如何解决

有的做法是使用枚举或者Constants常量类来实现,这种情况下在量少的前提是没问题的,而且一旦需要修改就及其避免修改源码;随着系统的开发拓展,后期将无法维护,甚至命名困难等问题。

所以通常把字典放在数据库,这样后期的维护变更就比较简单,也可以在不用修改代码的情况下修改配置。还有,对于某些固定的数据字典(例如,星期,月份等)不允许修改。

但是,放在数据库又有着频繁访问数据库的问题,这不是我们希望的,这时候通常做法就是加缓存,降低访问数据库的频率。

字典表的设计:

通常分成两张表来实现,一个是字典类型,一个是字典

字典类型表: SYS_DICT_TYPE

字段名

类型

作用

备注

code

varchar

编码

主键

name

varchar

类型

展示用

字典表 : SYS_DICT

字段名

类型

作用

备注

code

varchar

编码

主键

type_code

varchar

类型code

外键

name

varchar

字典名

展示用

value

varchar

字典值

使用值

fixed

int

是否是固定的

default 0不固定,固定的话用1

以上是字典表的关键列和结构的设计,根据不同系统不同业务自定其他列

注意事项

字典类型应该是不可编辑的,因为字典类型通常会和具体代码实现紧密耦合,如果非要进行编辑话需要考虑到对代码的影响以及如何保证修改之后系统正常工作

字典分可编辑与不可编辑,所以在提供字典管理的时候需要注意fixed字段,针对固定的字典不提供编辑功能

字典与系统参数不要混为一谈,字典通常用于一类的数据,一组具有相同含义的数值(例如,供客户端下拉选择的枚举);而系统参数是针对某种配置或者某种系统常量的存在。

关于缓存

对于缓存,可能每个人的意见不同,有人认为缓存增加维护成本,一旦使用缓存,对于编辑的数据得立马刷新缓存,不然将会与预期不符,并且对于访问不频繁量少的数据还达不到使用缓存的级别;有人认为缓存提高效率,减少数据访问。

个人认为,不同项目不同应用场景使用缓存的条件不同,对于高频的数据或者对响应时间要求严格的系统可以增加缓存,但是带来的就是数据改动的同时需要及时更新缓存信息;对于对响应时间、业务要求较高的系统可以不用缓存,保证业务的正确性。所以,具体情况具体分析,没有哪一种是正确的,选择适合的就可以。


https://www.fengoutiyan.com/post/15710.html

相关文章:

  • 数据字典表如何设计
  • 数据库数据字典怎么写
  • mysql商城数据库表设计
  • mysql一对多表设计
  • MySQL表注释
  • 多对多数据库表设计
  • mysql表结构
  • mysql用户表设计
  • 鏡像模式如何設置在哪,圖片鏡像操作
  • 什么軟件可以把圖片鏡像翻轉,C#圖片處理 解決左右鏡像相反(旋轉圖片)
  • 手機照片鏡像翻轉,C#圖像鏡像
  • 視頻鏡像翻轉軟件,python圖片鏡像翻轉_python中鏡像實現方法
  • 什么軟件可以把圖片鏡像翻轉,利用PS實現圖片的鏡像處理
  • 照片鏡像翻轉app,java實現圖片鏡像翻轉
  • 什么軟件可以把圖片鏡像翻轉,python圖片鏡像翻轉_python圖像處理之鏡像實現方法
  • matlab下載,matlab如何鏡像處理圖片,matlab實現圖像鏡像
  • 圖片鏡像翻轉,MATLAB:鏡像圖片
  • 鏡像翻轉圖片的軟件,圖像處理:實現圖片鏡像(基于python)
  • canvas可畫,JavaScript - canvas - 鏡像圖片
  • 圖片鏡像翻轉,UGUI優化:使用鏡像圖片
  • Codeforces,CodeForces 1253C
  • MySQL下載安裝,Mysql ERROR: 1253 解決方法
  • 勝利大逃亡英雄逃亡方案,HDU - 1253 勝利大逃亡 BFS
  • 大一c語言期末考試試題及答案匯總,電大計算機C語言1253,1253《C語言程序設計》電大期末精彩試題及其問題詳解
  • lu求解線性方程組,P1253 [yLOI2018] 扶蘇的問題 (線段樹)
  • c語言程序設計基礎題庫,1253號C語言程序設計試題,2016年1月試卷號1253C語言程序設計A.pdf
  • 信奧賽一本通官網,【信奧賽一本通】1253:抓住那頭牛(詳細代碼)
  • c語言程序設計1253,1253c語言程序設計a(2010年1月)
  • 勝利大逃亡英雄逃亡方案,BFS——1253 勝利大逃亡
  • 直流電壓測量模塊,IM1253B交直流電能計量模塊(艾銳達光電)
  • c語言程序設計第三版課后答案,【渝粵題庫】國家開放大學2021春1253C語言程序設計答案
  • 18轉換為二進制,1253. 將數字轉換為16進制
  • light-emitting diode,LightOJ-1253 Misere Nim
  • masterroyale魔改版,1253 Dungeon Master
  • codeformer官網中文版,codeforces.1253 B
  • c語言程序設計考研真題及答案,2020C語言程序設計1253,1253計算機科學與技術專業C語言程序設計A科目2020年09月國家開 放大學(中央廣播電視大學)
  • c語言程序設計基礎題庫,1253本科2016c語言程序設計試題,1253電大《C語言程序設計A》試題和答案200901
  • 肇事逃逸車輛無法聯系到車主怎么辦,1253尋找肇事司機