我的桌子:
create table MyTable ( Id int identity(1,1) not null,MyStatus char(2) not null ) insert into MyTable(MyStatus) select 'A'
类和枚举:
public class MyTable { public virtual int Id { get; set; } public virtual MyTableStatus MyStatus { get; set; } } public enum MyTableStatus { A,B }
制图:
public MyTableMap() { Id(x => x.Id); Map(x => x.MyStatus); }
当我执行以下测试时,我得到System.FormatException:输入字符串格式不正确…
[Test] public void Blah() { MyTable myTable = Session.Get<MyTable>(1); Assert.That(myTable.MyStatus,Is.EqualTo(MyTableStatus.A)); }
编辑 – 我在现有数据库上编写应用程序,我无法轻易修改,因为它也被其他应用程序使用.所以数据库中的一些字段(我想在我的应用程序中表示为枚举)是int类型和一些char(2)类型.
解决方法
您需要创建自定义IUserType以将枚举转换为其字符串表示形式并返回.有一个
good example in C# here和一个
example in VB.NET for working with enums here(向下滚动到实现IUserType).