你应该知道的States字段使用规范

所属分类: 数据库 / 数据库其它 阅读数: 149
收藏 0 赞 0 分享

前言

最近在工作中了遇到了一些内容,觉着有必要和大家分享下,我们为了统一数据库表的状态字段,统一数据库表设计,简化字段在程序开发中的使用方式,下面话不多说了,来一起看看详细的介绍吧。

解决方式

States对应位域枚举StatesFlags。

/// <summary>
 /// 数据状态枚举
 /// </summary>
 [Flags]
 [DataContract]
 [EnumDescription("状态")]
 public enum StatesFlags
 {
  /// <summary>
  /// 可用状态
  /// </summary>
  [XmlEnum("1")]
  [EnumDescription("可用")]
  [EnumMember]
  Enabled = 1,
  /// <summary>
  /// 停用状态
  /// </summary>
  [XmlEnum("2")]
  [EnumDescription("停用")]
  [EnumMember]
  Disabled = 1 << 1,
  /// <summary>
  /// 移除(相当于逻辑删除)
  /// </summary>
  [XmlEnum("4")]
  [EnumDescription("移除")]
  [EnumMember]
  Removed = 1 << 2,
  /// <summary>
  /// 已确认(已经审核通过)
  /// </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
 }

业务模型使用方式

在业务模型中,需要关注模型的特定状态集,写入新的状态时使用模型中的States, 读取时每一个状态独立提供读取实现。如下图中IsRemoved状态 以后大家一看代码就知道这个模型到底有几个状态

///<sumary>
  /// 状态集,写
  ///</sumary>
  public StatesFlags States { get; set; }
  /// <summary>
  /// 只读
  /// </summary>
  public bool IsRemoved => States.HasFlag(StatesFlags.Removed);

StatesFlags的4个扩展方法

/// <summary>
 /// 数据状态枚举
 /// </summary>
 public static class StatesFlagsExtends
 {
  /// <summary>
  /// 设置可用
  /// </summary>
  /// <param name="states">状态</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>
  /// 设置停用
  /// </summary>
  /// <param name="states">状态</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>
  /// 移除状态
  /// </summary>
  /// <param name="states">状态</param>
  /// <param name="state">要移除的状态</param>
  public static StatesFlags RemoveState(this StatesFlags states, StatesFlags state)
  {
   //也可以通过如下计算去除一个状态states = states & ~StatesFlags.Disabled;
   return states ^ state;
  }
  /// <summary>
  /// 附加状态
  /// </summary>
  /// <param name="states">状态</param>
  /// <param name="state">要附加的状态</param>
  public static StatesFlags AttachState(this StatesFlags states, StatesFlags state)
  {
   return states | state;
  }

 }

由于Enable和Disable是互斥的,所以对应有SetDisable、SetEnable 。其它非互斥状态 提供 AttachState、RemoveState用于附加或移除状态。 如出现新的状态在StatesFlags中添加,状态为位域枚举,使用连续的数字移位操作,增加代码可读性。

附扩展方式测试代码

[TestClass]
 public class StatesFlagsTest
 {
  [TestMethod]
  public void TestStatesExtends()
  {
   //赋初值 在用、锁定、移除
   var state = StatesFlags.Enabled | StatesFlags.Locked | StatesFlags.Removed;
   //调用SetDisable方法,设为停用
   state = state.SetDisable();
   Assert.IsTrue(!state.HasFlag(StatesFlags.Enabled));
   Assert.IsTrue(state.HasFlag(StatesFlags.Disabled));
   //调用SetEnable方法,设为在用
   state = state.SetEnable();
   Assert.IsTrue(state.HasFlag(StatesFlags.Enabled));
   Assert.IsTrue(!state.HasFlag(StatesFlags.Disabled));
   //调用RemoveState方法,移除状态
   state = state.RemoveState(StatesFlags.Locked);
   Assert.IsTrue(!state.HasFlag(StatesFlags.Locked));
   Assert.IsTrue(state.HasFlag(StatesFlags.Removed));
   //调用AttachState方法,附加状态
   state = state.AttachState(StatesFlags.Confirmed);
   Assert.IsTrue(state.HasFlag(StatesFlags.Confirmed));
   //直接调用方法,不赋值不能改变states的值
   state.AttachState(StatesFlags.Locked);
   Assert.IsTrue(!state.HasFlag(StatesFlags.Locked));

  }
 }

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

更多精彩内容其他人还在看

sql 左连接和右连接的使用技巧(left join and right join)

今天做项目,发现左右连接是不一样的。主要是说明了区别,是不是必须用左连接或右连接,大家可以根据需要选择。
收藏 0 赞 0 分享

mysql "group by"与"order by"的研究--分类中最新的内容

这两天让一个数据查询难了。主要是对group by 理解的不够深入。才出现这样的情况
收藏 0 赞 0 分享

MSSQL转MySQL数据库的实际操作记录

今天把一个MSSQL的数据库转成MySQL,在没有转换工具的情况下,对于字段不多的数据表我用了如下手功转换的方法,还算方便。MSSQL使用企业管理器操作,MySQL用phpmyadmin操作。
收藏 0 赞 0 分享

程序员应该知道的数据库设计的两个误区

在几乎所有的企业级应用程序中,包括各种MIS、ERP、CRM等等,都会使用数据库,这样的好处是显而易见的,很容易地实现了数据层和业务逻辑层的分离,而且对于性能的优化也在一定程度上提供了便利。
收藏 0 赞 0 分享

大数据量,海量数据处理方法总结

大数据量的问题是很多面试笔试中经常出现的问题,比如baidu google 腾讯这样的一些涉及到海量数据的公司经常会问到。
收藏 0 赞 0 分享

MDAC2.8 安装问题与解决方法

根据Windows XP的版本不同,有的版本需要安装MDAC2.8,一般Windows XP SP2或以上版本就不需要安装。不需要安装时系统会提示“MDAC 2.8 RTM 与此版本 Windows 不兼容。现在它的所有功能都成为 Windows 的一部分”。
收藏 0 赞 0 分享

SQLServer 2005 和Oracle 语法的一点差异小结

Microsoft SQL Server 和Oracle 语法的一点差异小结,需要的朋友可以参考下。
收藏 0 赞 0 分享

数据库设计规范化的五个要求 推荐收藏

通常情况下,可以从两个方面来判断数据库是否设计的比较规范。一是看看是否拥有大量的窄表,二是宽表的数量是否足够的少。
收藏 0 赞 0 分享

数据库为何要建立索引的原因说明

数据库索引是为了增加查询速度而对表字段附加的一种标识。见过很多人机械的理解索引的概念,认为增加索引只有好处没有坏处。
收藏 0 赞 0 分享

数据库测试 实用技巧及测试方法

软件应用程序已经离不开数据库。无论是在Web、桌面应用、客户端服务器、企业和个人业务,都需要数据库在后端操作。
收藏 0 赞 0 分享
查看更多