c# – 使用byte作为主键数据类型

前端之家收集整理的这篇文章主要介绍了c# – 使用byte作为主键数据类型前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用实体框架代码优先.我有一个表不会超过100行,我想使用数据类型字节(sql Server中的tinyint)作为主键.

这是我到目前为止:

[Key]
public byte Id { get; set; }

问题是当Entity Framework创建数据库时,它没有设置允许行在插入时自动递增的标识规范属性.

如果我将数据类型更改为Int16(sql Server中的smallint),一切都很完美.

有没有办法告诉实体框架设置自动增量属性,还是一个字节不能用作实体框架代码优先的主键?

解决方法

支持字节类型作为键和标识列.将字节主键标记为标识不是默认设置.但您可以覆盖此默认值:
[Key,DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public byte Id { get; set; }

明确地设置Identity选项对于int,long和short(以及可能更多类型?)不是必需的,但它是一个字节(在sql Server中为tinyint).我通过测试得出结论,但无法在任何地方找到正式记录.

猜你在找的C#相关文章