你應(yīng)該知道的States字段使用規(guī)范
前言
最近在工作中了遇到了一些內(nèi)容,覺著有必要和大家分享下,我們?yōu)榱私y(tǒng)一數(shù)據(jù)庫表的狀態(tài)字段,統(tǒng)一數(shù)據(jù)庫表設(shè)計,簡化字段在程序開發(fā)中的使用方式,下面話不多說了,來一起看看詳細的介紹吧。
解決方式
States對應(yīng)位域枚舉StatesFlags。
/// <summary> /// 數(shù)據(jù)狀態(tài)枚舉 /// </summary> [Flags] [DataContract] [EnumDescription("狀態(tài)")] public enum StatesFlags { /// <summary> /// 可用狀態(tài) /// </summary> [XmlEnum("1")] [EnumDescription("可用")] [EnumMember] Enabled = 1, /// <summary> /// 停用狀態(tài) /// </summary> [XmlEnum("2")] [EnumDescription("停用")] [EnumMember] Disabled = 1 << 1, /// <summary> /// 移除(相當(dāng)于邏輯刪除) /// </summary> [XmlEnum("4")] [EnumDescription("移除")] [EnumMember] Removed = 1 << 2, /// <summary> /// 已確認(已經(jīng)審核通過) /// </summary> [XmlEnum("8")] [EnumDescription("已確認")] [EnumMember] Confirmed = 1 << 3, /// <summary> /// 鎖定 /// </summary> [XmlEnum("16")] [EnumDescription("鎖定")] [EnumMember] Locked = 1 << 4, /// <summary> /// 鎖定登錄 /// </summary> [XmlEnum("32")] [EnumDescription("鎖定登錄")] [EnumMember] LockLogin = 1 << 5 }
業(yè)務(wù)模型使用方式
在業(yè)務(wù)模型中,需要關(guān)注模型的特定狀態(tài)集,寫入新的狀態(tài)時使用模型中的States, 讀取時每一個狀態(tài)獨立提供讀取實現(xiàn)。如下圖中IsRemoved狀態(tài) 以后大家一看代碼就知道這個模型到底有幾個狀態(tài)
///<sumary> /// 狀態(tài)集,寫 ///</sumary> public StatesFlags States { get; set; } /// <summary> /// 只讀 /// </summary> public bool IsRemoved => States.HasFlag(StatesFlags.Removed);
StatesFlags的4個擴展方法
/// <summary> /// 數(shù)據(jù)狀態(tài)枚舉 /// </summary> public static class StatesFlagsExtends { /// <summary> /// 設(shè)置可用 /// </summary> /// <param name="states">狀態(tài)</param> public static StatesFlags SetEnable(this StatesFlags states) { if (states.HasFlag(StatesFlags.Disabled)) states = states ^ StatesFlags.Disabled; if (!states.HasFlag(StatesFlags.Enabled)) states = states | StatesFlags.Enabled; return states; } /// <summary> /// 設(shè)置停用 /// </summary> /// <param name="states">狀態(tài)</param> public static StatesFlags SetDisable(this StatesFlags states) { if (states.HasFlag(StatesFlags.Enabled)) states = states ^ StatesFlags.Enabled; if (!states.HasFlag(StatesFlags.Disabled)) states = states | StatesFlags.Disabled; return states; } /// <summary> /// 移除狀態(tài) /// </summary> /// <param name="states">狀態(tài)</param> /// <param name="state">要移除的狀態(tài)</param> public static StatesFlags RemoveState(this StatesFlags states, StatesFlags state) { //也可以通過如下計算去除一個狀態(tài)states = states & ~StatesFlags.Disabled; return states ^ state; } /// <summary> /// 附加狀態(tài) /// </summary> /// <param name="states">狀態(tài)</param> /// <param name="state">要附加的狀態(tài)</param> public static StatesFlags AttachState(this StatesFlags states, StatesFlags state) { return states | state; } }
由于Enable和Disable是互斥的,所以對應(yīng)有SetDisable、SetEnable 。其它非互斥狀態(tài) 提供 AttachState、RemoveState用于附加或移除狀態(tài)。 如出現(xiàn)新的狀態(tài)在StatesFlags中添加,狀態(tài)為位域枚舉,使用連續(xù)的數(shù)字移位操作,增加代碼可讀性。
附擴展方式測試代碼
[TestClass] public class StatesFlagsTest { [TestMethod] public void TestStatesExtends() { //賦初值 在用、鎖定、移除 var state = StatesFlags.Enabled | StatesFlags.Locked | StatesFlags.Removed; //調(diào)用SetDisable方法,設(shè)為停用 state = state.SetDisable(); Assert.IsTrue(!state.HasFlag(StatesFlags.Enabled)); Assert.IsTrue(state.HasFlag(StatesFlags.Disabled)); //調(diào)用SetEnable方法,設(shè)為在用 state = state.SetEnable(); Assert.IsTrue(state.HasFlag(StatesFlags.Enabled)); Assert.IsTrue(!state.HasFlag(StatesFlags.Disabled)); //調(diào)用RemoveState方法,移除狀態(tài) state = state.RemoveState(StatesFlags.Locked); Assert.IsTrue(!state.HasFlag(StatesFlags.Locked)); Assert.IsTrue(state.HasFlag(StatesFlags.Removed)); //調(diào)用AttachState方法,附加狀態(tài) state = state.AttachState(StatesFlags.Confirmed); Assert.IsTrue(state.HasFlag(StatesFlags.Confirmed)); //直接調(diào)用方法,不賦值不能改變states的值 state.AttachState(StatesFlags.Locked); Assert.IsTrue(!state.HasFlag(StatesFlags.Locked)); } }
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
Navicat?premium?for?mac?12的安裝破解圖文教程
Navicat Premium是一款數(shù)據(jù)庫管理工具,將此工具連接數(shù)據(jù)庫,你可以從中看到各種數(shù)據(jù)庫的詳細信息,這篇文章主要介紹了Mac下Navicat?premium?for?mac?12的安裝破解過程,需要的朋友可以參考下2024-01-01SQL中case?when?then?else?end用法實例
CASE WHEN THEN ELSE END是一個固定搭配,這樣排列是想把通過格式把邏輯展示出來,CASE告訴計算機接下來是條件句式了,下面這篇文章主要給大家介紹了關(guān)于SQL中case?when?then?else?end用法的相關(guān)資料,需要的朋友可以參考下2023-02-02談?wù)剶?shù)據(jù)庫的字段設(shè)計的幾個心得
今天小編就為大家分享一篇關(guān)于談?wù)剶?shù)據(jù)庫的字段設(shè)計的幾個心得,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03sql2005可實時監(jiān)測數(shù)據(jù)庫版本控制SQL的觸發(fā)器
用于sql2005實時監(jiān)測數(shù)據(jù)庫版本控制SQL的觸發(fā)器2008-10-10數(shù)據(jù)設(shè)計之權(quán)限的實現(xiàn)
這篇文章主要介紹了數(shù)據(jù)設(shè)計之權(quán)限的實現(xiàn),文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下2022-08-08設(shè)置CA證書來強化PostgreSQL的安全性的教程
這篇文章主要介紹了設(shè)置CA證書來強化PostgreSQL的安全性的教程,主要用到了CA私鑰,需要的朋友可以參考下2015-04-04使用Navicat連接opengauss數(shù)據(jù)庫完整步驟(詳細圖文)
Navicat是一套快速、可靠并價格相當(dāng)便宜的數(shù)據(jù)庫管理工具,專為簡化數(shù)據(jù)庫的管理及降低系統(tǒng)管理成本而設(shè),下面這篇文章主要給大家介紹了關(guān)于使用Navicat連接opengauss數(shù)據(jù)庫的完整步驟,需要的朋友可以參考下2024-02-02