简要咨询咨询QQ网站导航网站搜索手机站点联系我们设为首页加入收藏 

ADO.NET Entity Framework 4中枚举的使用

来源:易贤网   阅读:913 次  日期:2014-08-20 13:58:04

温馨提示:易贤网小编为您整理了“ADO.NET Entity Framework 4中枚举的使用”,方便广大网友查阅!

本文将通过ADO.NET Entity Framework 4中枚举的使用介绍,带领大家走进ADO.NET的世界。

枚举(Enum)是一种常用的类型,如用于表示状态、类型等参数。但目前它不会被官方地在ADO.NET Entity Framework中进行支持。本文介绍的是通过复杂类型(Complex Types)在ADO.NET Entity Framework 4中使用枚举。

这种方法需要使用POCO类,而不能使用Visual Studio自动生成的类。因为我们需要手动为复杂类型编写代码。

数据库脚本:

if exists (select 1

from sysobjects

where id = object_id('Account')

and type = 'U')

drop table Account go create table Account

(

ID uniqueidentifier not null default NewSequentialID(),

UserName nvarchar(20) not null,

Password varchar(40) not null,

Email nvarchar(100) not null,

Role int not null,

constraint PK_ACCOUNT primary key (ID)

)

insert into Account (UserName ,Password,Email ,Role ) values ('Test1','Test1','test1',1)

insert into Account (UserName ,Password,Email ,Role ) values ('Test2','Test2','test2',1)

insert into Account (UserName ,Password,Email ,Role ) values ('Test3','Test3','test3',2)

这是一个用于存放帐号信息的数据表,Role是个枚举类型,在数据库中用int类型。

我们按常规做法写一个用于表示Role的枚举类型

public enum AccountRoleEnum {

Admin = 1,

User = 2

}

然后写一个复杂类型用于在枚举类型和数据库的int类型之间做变换。复杂类型只有在ADO.NET Entity Framework 4中才有。

public partial class RoleWrapper

{

private AccountRoleEnum m_orderStatus;

public int Value

{

get {

return (int)m_orderStatus;

}

set {

m_orderStatus = (AccountRoleEnum)value;

} }

public AccountRoleEnum EnumValue

{

get {

return m_orderStatus;

}

set {

m_orderStatus = value;

}

}

public static implicit operator RoleWrapper(AccountRoleEnum role)

{

return new RoleWrapper {

EnumValue = role

};

}

public static implicit operator AccountRoleEnum(RoleWrapper role)

{

if (role == null)

return AccountRoleEnum.User;

return role.EnumValue;

}

} 最后的2个方法用于隐式类型重载,也就是对类型进行变换。

然后我们写Account实体。

public class Account

{

public Guid ID

{

get;

set;

}

public string UserName { get; set;

}

public string Password

{

get;

set;

}

public string Email

{

get;

set;

}

public RoleWrapper Role

{

get;

set;

} 和实体框架上下文。

public class EntitiesContext : ObjectContext

{

public EntitiesContext()

: base("name=Entities", "Entities")

{

_accounts = CreateObjectSet();

}

public ObjectSet Accounts

{

get

{

return _accounts;

}

}

private ObjectSet _accounts;

}

这样,主要的工作就已经完成了,在比较时可以使用

account.Role == AccountRoleEnum.Admin 但是在涉及到数据库的查询时,这样的写法是会报错的,只能使用

EntitiesContext db = new EntitiesContext(); db.Accounts.Where(c => c.Role.Value == (int)AccountRoleEnum.Admin);

更多信息请查看IT技术专栏

更多信息请查看网络编程
点此处就本文及相关问题在本站进行非正式的简要咨询(便捷快速)】     【点此处查询各地各类考试咨询QQ号码及交流群
上一篇:ado.net快速上手疑问及解答
下一篇:ADO.NET实用经验介绍
易贤网手机网站地址:ADO.NET Entity Framework 4中枚举的使用
由于各方面情况的不断调整与变化,易贤网提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!