Dapper.net 2.0 无法抛出异常
Dapper.net 2.0 Unable to cast exception
我收到的异常很清楚。我以前确实用过 dapper,效果很好,但现在遇到困难了。
无法转换类型为 'System.Func2[System.Data.IDataReader,WebApplication1.Modal.Users]' to type 'System.Func
2[System.Data.IDataReader,System.Object]' 的对象。
用户 Class 是
public class Users : MainSharedTable
{
public int FkReceiverID { get; set; }
public string Password { get; set; }
}
MainSharedTable 是
public class MainSharedTable
{
public int ID { get; set; }
public bool Active { get; set; }
}
异常发生在这里
public IEnumerable<Users> GetAll()
{
var conn = GetOpenConnection();
var data = conn.Query<Users>("SELECT * FROM arabaicsms.users "); // error happens here
ConnectionClose();
return data;
}
感谢任何帮助
注意:我的数据库是 MYSQL 如果不转换返回的对象,我会收到一个字典
全栈
[InvalidCastException: Unable to cast object of type 'System.Func`2[System.Data.IDataReader,WebApplication1.Modal.Users]' to type 'System.Func`2[System.Data.IDataReader,System.Object]'.]
Dapper.SqlMapper.GetTypeDeserializerImpl(Type type, IDataReader reader, Int32 startBound, Int32 length, Boolean returnNullIfFirstMissing) +10454
Dapper.TypeDeserializerCache.GetReader(IDataReader reader, Int32 startBound, Int32 length, Boolean returnNullIfFirstMissing) +412
Dapper.TypeDeserializerCache.GetReader(Type type, IDataReader reader, Int32 startBound, Int32 length, Boolean returnNullIfFirstMissing) +379
Dapper.SqlMapper.GetTypeDeserializer(Type type, IDataReader reader, Int32 startBound, Int32 length, Boolean returnNullIfFirstMissing) +72
Dapper.SqlMapper.GetDeserializer(Type type, IDataReader reader, Int32 startBound, Int32 length, Boolean returnNullIfFirstMissing) +520
Dapper.<QueryImpl>d__58`1.MoveNext() +1293
System.Collections.Generic.List`1..ctor(IEnumerable`1 collection) +387
System.Linq.Enumerable.ToList(IEnumerable`1 source) +119
Dapper.SqlMapper.Query(IDbConnection cnn, String sql, Object param, IDbTransaction transaction, Boolean buffered, Nullable`1 commandTimeout, Nullable`1 commandType) +787
WebApplication1.BL.UsersBs.GetAll() in C:\Users\pc\documents\visual studio 2015\Projects\ArabaicSmsWeb\WebApplication1\BL\UsersBs.cs:25
WebApplication1.login.Page_Load(Object sender, EventArgs e) in C:\Users\pc\documents\visual studio 2015\Projects\ArabaicSmsWeb\WebApplication1\login.aspx.cs:17
System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender, EventArgs e) +51
System.Web.UI.Control.OnLoad(EventArgs e) +95
System.Web.UI.Control.LoadRecursive() +59
System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +780
数据库中的table如下
周围没有什么奇怪的,我什至将 table 后者大写并使它们变小,但同样的错误存在
能不能换个函数试试
public IEnumerable<Users> GetAll()
{
var conn = GetOpenConnection();
IEnumerable<Users> data = conn.Query<Users>("SELECT * FROM arabaicsms.users "); // error happens here
ConnectionClose();
return data;
}
您获得上述异常的唯一方法是当您针对不支持委托 co/contra 方差(3.5 及更早版本)和 运行 代码片段的 NET Framework 版本时:
Delegate funcA = new Func<string, string>(s => s);
var funcB = (Func<string, object>)funcA;
这是Dapper.SqlMapper.GetTypeDeserializerImpl
方法的简化版本。最后一行适用于 NET Framework 4.0 + 并在 NET Framework 3.5 上抛出。
要解决此问题,请在您的项目中以 NET Framework 4.0 或更高版本为目标,或者安装适合您的 NET Framework 版本的 Dapper 包(如果存在)。
我收到的异常很清楚。我以前确实用过 dapper,效果很好,但现在遇到困难了。
无法转换类型为 'System.Func2[System.Data.IDataReader,WebApplication1.Modal.Users]' to type 'System.Func
2[System.Data.IDataReader,System.Object]' 的对象。
用户 Class 是
public class Users : MainSharedTable
{
public int FkReceiverID { get; set; }
public string Password { get; set; }
}
MainSharedTable 是
public class MainSharedTable
{
public int ID { get; set; }
public bool Active { get; set; }
}
异常发生在这里
public IEnumerable<Users> GetAll()
{
var conn = GetOpenConnection();
var data = conn.Query<Users>("SELECT * FROM arabaicsms.users "); // error happens here
ConnectionClose();
return data;
}
感谢任何帮助 注意:我的数据库是 MYSQL 如果不转换返回的对象,我会收到一个字典
全栈
[InvalidCastException: Unable to cast object of type 'System.Func`2[System.Data.IDataReader,WebApplication1.Modal.Users]' to type 'System.Func`2[System.Data.IDataReader,System.Object]'.]
Dapper.SqlMapper.GetTypeDeserializerImpl(Type type, IDataReader reader, Int32 startBound, Int32 length, Boolean returnNullIfFirstMissing) +10454
Dapper.TypeDeserializerCache.GetReader(IDataReader reader, Int32 startBound, Int32 length, Boolean returnNullIfFirstMissing) +412
Dapper.TypeDeserializerCache.GetReader(Type type, IDataReader reader, Int32 startBound, Int32 length, Boolean returnNullIfFirstMissing) +379
Dapper.SqlMapper.GetTypeDeserializer(Type type, IDataReader reader, Int32 startBound, Int32 length, Boolean returnNullIfFirstMissing) +72
Dapper.SqlMapper.GetDeserializer(Type type, IDataReader reader, Int32 startBound, Int32 length, Boolean returnNullIfFirstMissing) +520
Dapper.<QueryImpl>d__58`1.MoveNext() +1293
System.Collections.Generic.List`1..ctor(IEnumerable`1 collection) +387
System.Linq.Enumerable.ToList(IEnumerable`1 source) +119
Dapper.SqlMapper.Query(IDbConnection cnn, String sql, Object param, IDbTransaction transaction, Boolean buffered, Nullable`1 commandTimeout, Nullable`1 commandType) +787
WebApplication1.BL.UsersBs.GetAll() in C:\Users\pc\documents\visual studio 2015\Projects\ArabaicSmsWeb\WebApplication1\BL\UsersBs.cs:25
WebApplication1.login.Page_Load(Object sender, EventArgs e) in C:\Users\pc\documents\visual studio 2015\Projects\ArabaicSmsWeb\WebApplication1\login.aspx.cs:17
System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender, EventArgs e) +51
System.Web.UI.Control.OnLoad(EventArgs e) +95
System.Web.UI.Control.LoadRecursive() +59
System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +780
数据库中的table如下
周围没有什么奇怪的,我什至将 table 后者大写并使它们变小,但同样的错误存在
能不能换个函数试试
public IEnumerable<Users> GetAll()
{
var conn = GetOpenConnection();
IEnumerable<Users> data = conn.Query<Users>("SELECT * FROM arabaicsms.users "); // error happens here
ConnectionClose();
return data;
}
您获得上述异常的唯一方法是当您针对不支持委托 co/contra 方差(3.5 及更早版本)和 运行 代码片段的 NET Framework 版本时:
Delegate funcA = new Func<string, string>(s => s);
var funcB = (Func<string, object>)funcA;
这是Dapper.SqlMapper.GetTypeDeserializerImpl
方法的简化版本。最后一行适用于 NET Framework 4.0 + 并在 NET Framework 3.5 上抛出。
要解决此问题,请在您的项目中以 NET Framework 4.0 或更高版本为目标,或者安装适合您的 NET Framework 版本的 Dapper 包(如果存在)。