• Entity Framework 的枚举类型


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

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

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

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

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

    第三步:创建Enum值

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

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

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

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

    第七步:查看数据库

    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。

    复制代码
    public BlogCategoryType CategoryType
    {
        set
        {
            CategoryTypeByte = BitConverter.GetBytes((int)value)[0];
        }
    }
    复制代码

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

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

    复制代码
    public BlogCategoryType CategoryType
    {
        get
        {
            return (BlogCategoryType)BitConverter.ToInt32(
                new byte[] { CategoryTypeByte, 0x0, 0x0, 0x0 }, 0);
        }
    }
    复制代码

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

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

  • 相关阅读:
    XML炸弹
    IP分片攻击——就是发送部分分片报文,让对方一直等待从而耗对方内存的DoS攻击
    灰色软件——广告软件,拨号软件,远程访问软件等
    rootkit——一种特殊的恶意软件,它的功能是在安装目标上隐藏自身及指定的文件、进程和网络链接等信息,一般都和木马、后门等其他恶意程序结合使用
    漏洞利用 Exploit---利用默认口令、IP假冒、应用漏洞
    SequenceFile文件
    随机森林和GBDT的几个核心问题
    机器学习中的算法(1)-决策树模型组合之随机森林与GBDT
    直方图中最大矩形面积
    openMP多线程编程
  • 原文地址:https://www.cnblogs.com/xuxin-1989/p/4515633.html
Copyright © 2020-2023  润新知