Entity Framework 的枚举类型

时间:2023-01-06 20:07:41

新增数据模型,新增“实体”之后,新增“枚举类型”,创建Enum值,将“实体”中的列和Enum关联,选中“实体”中的列属性改变类型为Enum名称,生成数据库……

如下转自:http://item.congci.com/item/entity-framework-meiju-leixing-enum

第一步:先创建一个实体对象,在VS 2012里面实体对象还可以修改实体颜色

Entity Framework 的枚举类型

第二步:对象已经有了,接着创建一个Type,Type为Enum,内部与外部(Internal and External),在空白处右键(学计算机编程时,老师就给我们说,遇到不会就先右键,之后再Google

Entity Framework 的枚举类型

打开模型浏览器,同样可以添加Enum

Entity Framework 的枚举类型

第三步:创建Enum值

Entity Framework 的枚举类型

Entity Framework 的枚举类型

第四步:让Type引用Enum,选中Type ,查看属性

Entity Framework 的枚举类型

第五步:生成数据库并添加数据

Entity Framework 的枚举类型

第六步:运行看一下结果,先猜一下输出的类型 是 ?

Entity Framework 的枚举类型

很明显,输出的不是1,而是External,这正是我们在绑定时要的值,想不想再看一下数据库里面存储的是什么值呢?

第七步:查看数据库

Entity Framework 的枚举类型

Type的值是 1 ,不是External,这样是不是提高了我们的开发效率。


解决Entity Framework中枚举类型与tinyint的映射问题

在代码世界中,有一种常见的“变” —— 类型转变。这篇文章分享的就是如何通过类型转变,解决Entity Framework(5.0之前的版本)中枚举类型(实体)与 tinyint(数据库字段类型)的映射问题。

对于需要进行持久化的枚举类型,我们通常在数据库表中建立一个对应的tinyint类型的字段。

如果我们使用Entity Framework作为ORM,将面临两个问题:

1. EF不支持枚举类型的直接映射(5.0之前的版本)

2. 对于tinyint数据库类型,不管对应的实体属性定义的是什么类型,EF始终映射为byte类型。

相应的解决方法也不难:

1. 给实体增加一个“中间人”属性,与数据库中对应的字段进行映射,然后再转换为枚举类型。

2. 将这个“中间人”属性定义为byte类型。

于是就有了下面的代码:

public class BlogCategory
{
public CategoryType CategoryType { get; set; } public byte CategoryTypeByte { get; set; }
}

BlogCategory.CategoryType是枚举类型的属性,是代码中实际访问的属性;BlogCategory.CategoryTypeByte是增加的“中间人”属性,专用于映射数据库中tinyint类型的字段。

随之,难题出现了,如何在枚举类型与bype类型之间进行转换呢?在读取BlogCategory.CategoryType属性时,需要将byte转换为枚举;在写入BlogCategory.CategoryType属性时,需要将枚举转换为byte。

枚举类型可以方便地转换为int类型,但int类型是32位的(4个byte)。也就是说,这两者尺码不一样,大转小,要减肥;小转大,要增胖。

对于类型转换安全问题,我们无需担心,因为数据库中是tinyint类型,数据的长度不会超过1个byte。

那如何转换呢?

.NET提供了一个强大的转换器 —— System.BitConverter,让我们来看看如何通过它实现72变。

1. 大转小,减肥,枚举转byte。

Entity Framework 的枚举类型
public BlogCategoryType CategoryType
{
set
{
CategoryTypeByte = BitConverter.GetBytes((int)value)[0];
}
}
Entity Framework 的枚举类型

将枚举转换为int,再将int转换为byte数组,然后取第一个元素。

2. 小转大,增胖,byte转枚举。

Entity Framework 的枚举类型
public BlogCategoryType CategoryType
{
get
{
return (BlogCategoryType)BitConverter.ToInt32(
new byte[] { CategoryTypeByte, 0x0, 0x0, 0x0 }, 0);
}
}
Entity Framework 的枚举类型

增加三个值为0的byte,与CategoryTypeByte组合为长度为4的byte数组(因为int类型的需要),然后将这个byte数组转换为int类型。

注:该解决方法已通过临床验证,确实有疗效,请放心使用!

Entity Framework 的枚举类型的更多相关文章

  1. 解决Entity Framework中DateTime类型字段异常

    从 datetime2 数据类型到 datetime 数据类型的转换产生一个超出范围的值 具体的错误原因是:C#中的DateTime类型比SqlServer中的datetime范围大.SqlServe ...

  2. Entity Framework Core 软删除与查询过滤器

    本文翻译自<Entity Framework Core: Soft Delete using Query Filters>,由于水平有限,故无法保证翻译完全正确,欢迎指出错误.谢谢! 注意 ...

  3. 【EF】Entity Framework Core 软删除与查询过滤器

    本文翻译自<Entity Framework Core: Soft Delete using Query Filters>,由于水平有限,故无法保证翻译完全正确,欢迎指出错误.谢谢! 注意 ...

  4. 【配置属性】—Entity Framework 对应表字段的类型的设定配置方法

    摘自:http://www.cnblogs.com/nianming/archive/2012/11/07/2757997.html Entity Framework Code First的默认行为是 ...

  5. Entity Framework 教程——Entity Framework中的实体类型

    Entity Framework中的实体类型 : 在之前的章节中我们介绍过从已有的数据库中创建EDM,它包含数据库中每个表所对应的实体.在EF 5.0/6.0中,存在POCO 实体和动态代理实体两种. ...

  6. 《Entity Framework 6 Recipes》中文翻译系列 &lpar;25&rpar; ------ 第五章 加载实体和导航属性之加载完整的对象图和派生类型上的导航属性

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-5  加载完整的对象图 问题 你有一个包含许多关联实体的模型,你想在一次查询中, ...

  7. Entity Framework Code First (四)Fluent API - 配置属性&sol;类型

    上篇博文说过当我们定义的类不能遵循约定(Conventions)的时候,Code First 提供了两种方式来配置你的类:DataAnnotations 和 Fluent API, 本文将关注 Flu ...

  8. Entity Framework 学习中级篇1—EF支持复杂类型的实现

    本节,将介绍如何手动构造复杂类型(ComplexType)以及复杂类型的简单操作. 通常,复杂类型是指那些由几个简单的类型组合而成的类型.比如:一张Customer表,其中有FristName和Las ...

  9. 关于Entity Framework更新的几种方式以及可能遇到的问题(附加类型&OpenCurlyDoubleQuote;Model”的实体失败,因为相同类型的其他实体已具有相同的主键值)在使用 &quot&semi;Attach&quot&semi; 方法或者将实体的状态设置为 &quot&semi;Unchanged&quot&semi; 或 &quot&semi;Modified&quot&semi; 时如果图形中的任何实体具有冲突键值,则可能会发生上述行为

    在日常使用Entity Framework中,数据更新通常会用到.下面就简单封装了一个DBContext类 public partial class EFContext<T> : DbCo ...

随机推荐

  1. 总结一下Android中主题&lpar;Theme&rpar;的正确玩法

    在AndroidManifest.xml文件中有<application android:theme="@style/AppTheme">,其中的@style/AppT ...

  2. C&plus;&plus;学习笔记22:设备

    设备类型 设备文件的性质 设备文件不是普通的磁盘文件 读写设备的数据需要与相应的设备驱动器通信 设备文件的类型 字符设备:读写串行数据字节流,如串口.终端等 块设备:随机读写固定尺寸数据块,如磁盘设备 ...

  3. 【ntp】centos7下ntp服务器设置

    安装ntp #检查服务是否安装 rpm -q ntp #安装ntp服务器 yum -y install ntp 修改配置文件:/etc/ntp.conf 内容如下: restrict default ...

  4. solr返回的字段带有中括号问题

    在solr返回的结果集的content字段返回格式为: "content": ["测试content" ], 经过对比title 和content字段,发现co ...

  5. GridView 服务端控件添加 js

    针对服务端控件的 CommandField “Delete” 添加 js $("#GridView1").find("a").each( function() ...

  6. Codeforces 479E Riding in a Lift

    http://codeforces.com/problemset/problem/432/D 题目大意: 给出一栋n层的楼,初始在a层,b层不能去,每次走的距离必须小于当前位置到b的距离,问用电梯来回 ...

  7. 《Programming WPF》翻译 第8章 2&period;Timeline

    原文:<Programming WPF>翻译 第8章 2.Timeline Timeline代表了时间的延伸.它通常还描述了一个或多个在这段时间所发生的事情.例如,在前面章节描述的动画类型 ...

  8. python 利用 ogr 写入shp文件,数据格式

    python 利用 ogr 写入 shp 文件, 定义shp文件中的属性字段(field)的数据格式为: OFTInteger # 整型 OFTIntegerList # 整型list OFTReal ...

  9. &lbrack;20180118&rsqb;tstats的问题&period;txt

    [20180118]tstats的问题.txt --//关于使用tstats收集处理统计信息,可以看链接http://blog.itpub.net/267265/viewspace-1987839/ ...

  10. python使用分治法找序列最大值

    最近上算法导论课,说道分治法,回来想用python写写程序练练手,于是模仿一通写了如下的代码: __author__ = 'day' def ArrayMaxMin(Array): return ma ...