了解枚举 - 用作常量

时间:2013-04-23 20:19:03

标签: c# entity-framework enums

所以我试图使用枚举,可能是以错误的方式,因为我来自PHP。在C#中,我有一个全局类:

public static class GlobalTypes
{
    public enum assignmentType { SERV = "SERV", PROD = "PROD", PER = "PER", }
}

从那里开始我尝试与实体互动:

    public static IEnumerable<Person> getAllAgents(int id)
    {
        using (var db = new LocAppContext())
        {
            var person = (from p in db.Person
                          join la in db.LocationAssignment on p.id equals la.value
                          where la.locationID == id && la.type == GlobalTypes.assignmentType.PER
                          select p).ToList();

            return person;
        }

    }

但我收到错误:

  

运算符'=='不能应用于'string'类型的操作数   'LocApp.Helpers.Classes.LocationAssignments.GlobalTypes.assignmentType'

发生于

la.type == GlobalTypes.assignmentType.PER

我的逻辑,这是来自php,是我想要一个全局常量我可以调用任何地方在调用时“回显”该常量的值,所以常量值可以改变但我不需要在一百万个地方改变它。

想法?

2 个答案:

答案 0 :(得分:4)

如果你想要常量字符串,那么不要使用枚举。枚举用于整数类型。只需使用consts:

public static class MyClass
{
    public const string PROD = "PROD";
    public const string DEV = "DEV";
}

// elsewhere...
la.type == MyClass.PROD;

答案 1 :(得分:4)

快速回答:

public enum assignmentType { SERV, PROD, PER }

并在比较中(假设la.type返回一个字符串):

where la.locationID == id && la.type == GlobalTypes.assignmentType.PER.ToString()