我在这里看到了几个有关处理和持久保存枚举式值的最佳方法的问题/讨论(例如,持久化适用于枚举的数据,如何使用NHibernate来持久化枚举),我想问一下一般共识。
尤其是:
- 这些值应如何在代码中处理?
- 应该如何将它们持久保存到数据库中(作为文本/作为数字)?
- 不同解决方案的权衡是什么?
注意:我已将本问题中最初包含的解释移至答案。
我在这里看到了几个有关处理和持久保存枚举式值的最佳方法的问题/讨论(例如,持久化适用于枚举的数据,如何使用NHibernate来持久化枚举),我想问一下一般共识。
尤其是:
注意:我已将本问题中最初包含的解释移至答案。
Answers:
最初的文章对我来说不错。尽管如此,基于这些注释,似乎有关Java枚举的一些注释可能澄清不了什么。
根据定义,Java中的Enum类型是一个类,但是许多程序员往往会忘记这一点,因为它们像某些其他语言一样将其与“允许值列表”相关联。不仅如此。
因此,为避免这些switch语句,将一些代码和其他方法放在enum类中可能是合理的。几乎不需要创建单独的“枚举式真实类”。
还请考虑文档编制的要点-您是否要在数据库中记录枚举的实际含义?在反映值(您的枚举类型)的源代码中还是在某些外部文档中?我个人更喜欢源代码。
如果由于速度或其他原因要在数据库中将枚举值显示为整数,则该映射也应驻留在Java枚举中。默认情况下,您将获得字符串名称映射,对此我很满意。每个枚举值都有一个序号,但是直接使用序号作为代码和数据库之间的映射并不是很好,因为如果有人重新排序源代码中的值,则序号会改变。或在现有值之间添加其他枚举值。或去除一些价值。
(当然,如果有人在源代码中更改了枚举的名称,默认的字符串映射也会出错,但这不太可能偶然发生。而且,如果需要,可以通过进行一些运行时检查来更容易地防止这种情况的发生。并按照此处的建议检查数据库中的约束。)
我试图总结我的理解。如果有任何更正,请随时进行编辑。因此,它去了:
在代码中
在代码中,应使用语言的本机枚举类型(至少在Java和C#中)或使用诸如“ typesafe枚举模式”之类的方式来处理枚举。不推荐使用普通常量(整数或类似常量),因为这样会丢失类型安全性(并使您难以理解哪些值是合法输入的值,例如方法)。
两者之间的选择取决于要附加给枚举的附加功能:
特别是,至少在Java中,一个枚举不能从另一个类继承,因此,如果有多个具有相似行为的枚举要放入超类中,则不能使用Java的枚举。
持久枚举
要保留枚举,应为每个枚举值分配一个唯一的ID。可以是整数,也可以是短字符串。首选短字符串,因为它可以助记符(使DBA等更容易理解db中的原始数据)。
这种方法的一个问题是合法枚举值的列表存在于两个位置(代码和数据库)。这很难避免,因此通常被认为可以接受,但是有两种选择:
在C#的代码处理中,您错过了定义deltering 0值的过程。我几乎没有失败总是将我的第一个值声明为:
public enum SomeEnum
{
None = 0,
}
以便用作空值。由于支持类型是整数,并且整数默认为0,因此在很多地方了解枚举是否已通过编程方式进行设置非常有用。
Java或C#应该始终在代码中使用枚举。免责声明:我的背景是C#。
如果该值要保留到数据库中,则应明确定义每个枚举成员的整数值,以便以后的代码更改不会意外地更改转换后的枚举值,从而改变应用程序的行为。
值应始终作为整数值保存在数据库中,以防止枚举名称重构。保留有关Wiki中每个枚举的文档,并在数据库字段中添加注释,以指向记录该类型的Wiki页面。还将XML文档添加到包含指向Wiki条目的链接的枚举类型中,以便可通过Intellisense使用。
如果使用工具生成CRUD代码,则该工具应能够定义用于列的枚举类型,以便生成的代码对象始终使用枚举成员。
如果需要将自定义逻辑应用于枚举成员,则可以选择以下选项:
我没有尝试过,但是在SQL Server 2005或更高版本中,理论上您可以在数据库中注册C#代码,该代码将包含枚举信息以及将值转换为枚举以在视图或其他构造中使用的能力,从而提供了一种翻译数据,以便DBA易于使用。
由于需要额外的空间并且搜索速度较慢,因此将枚举的文本值存储在数据库中比存储整数更不受欢迎。有价值的是,它比数字具有更多的含义,但是数据库用于存储,表示层用于使外观看起来更好。
嗯,根据我的经验,将枚举用于将选项(作为标志)传递给即时方法调用以外的任何方法,都会switch
在某个时候导致-ing。
switch
语句)switch
如果没有其他类,最终将在扩展方法中使用-es)。因此,对于具有更多功能的枚举式实体,您应该花一些时间并将其创建为类,并牢记以下几点:
每次您在代码中使用“幻数”找到自己时,都会将其更改为枚举。除了节省时间(由于错误会在魔术消失时自动消除魔术……)之外,还可以节省您的视力和内存(有意义的枚举使代码更具可读性和自说明性),因为您猜到了什么—您很可能是维护和开发人员你自己的代码