我有一个类似于这样的类结构:
public abstract class Device
{
public int DeviceId { get; set; }
//Additional Properties
}
public class DeviceA : Device
{
//Specific Behaviour
}
public class DeviceB : Device
{
//Specific Behaviour
}
我需要检索设备列表或单个设备,该设备被实例化为适当的派生类型(基于数据库中设备记录中的类型值)。也就是说,Device
对象的集合应该包含多个不同类型的对象,所有这些对象都派生自Device
.
我已经通过以下方式实现了这一点,但是感觉有些不对劲。
public static IEnumerable<Device> AllDevices()
{
using (var connection = CreateConnection())
{
connection.Open();
return connection.Query<dynamic>("SELECT * FROM Device").Select<dynamic, Device>(d =>
{
Device device = null;
if (d.DeviceTypeID == 1)
device = new DeviceA();
else if (d.DeviceTypeID == 2)
device = new DeviceB();
else throw new Exception("Unknown Device");
device.DeviceId = d.DeviceID;
return device;
});
}
}
这是使用 Dapper 实现此目的的正确方法,还是有更好的方法?