Dapper.net 2.0 No se puede lanzar la excepción

asp.net c# dapper mysql

Pregunta

La excepción que estoy recibiendo es clara. Utilicé dapper antes y funcionó muy bien, pero ahora estoy teniendo dificultades.


No se puede convertir el objeto de tipo 'System.Func 2[System.Data.IDataReader,WebApplication1.Modal.Users]' to type 'System.Func 2 [System.Data.IDataReader, System.Object]'.

Clase de usuario es

public class Users : MainSharedTable
    {

        public int FkReceiverID { get; set; }
        public string Password { get; set; }

    }

MainSharedTable es

public class MainSharedTable 
    {
        public int ID { get; set; }
        public bool Active { get; set; }
    }

y la excepción sucede aquí

public   IEnumerable<Users> GetAll()
    {

            var conn = GetOpenConnection();
           var data = conn.Query<Users>("SELECT * FROM arabaicsms.users  "); // error happens here 
            ConnectionClose();

        return data;
    }

cualquier ayuda es apreciada nota: mi db es MYSQL y si no echas el objeto devuelto recibo un diccionario

completa pila

[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

la tabla en la base de datos es como abajo enter image description here

no hay nada extraño alrededor, incluso capitalice la tabla más tarde y también la hago pequeña, pero el mismo error está ahí

Respuesta aceptada

La única forma en que puede obtener la excepción antes mencionada es cuando se dirige a la versión de NET Framework que no admite la variación delegate co / contra (3.5 y anteriores) y ejecuta un fragmento de código como este:

Delegate funcA = new Func<string, string>(s => s);
var funcB = (Func<string, object>)funcA;

que es la versión simplificada del método Dapper.SqlMapper.GetTypeDeserializerImpl . La última línea funciona en NET Framework 4.0 + y arroja en NET Framework 3.5.

Para solucionar el problema, apunte a NET Framework 4.0 o posterior en su proyecto, o instale el paquete Dapper apropiado para su versión de NET Framework (si existe).


Respuesta popular

Puedes intentar cambiando tu función

public   IEnumerable<Users> GetAll()
    {

            var conn = GetOpenConnection();
           IEnumerable<Users> data = conn.Query<Users>("SELECT * FROM arabaicsms.users  "); // error happens here 
            ConnectionClose();

        return data;
    }


Licencia bajo: CC-BY-SA with attribution
No afiliado con Stack Overflow
¿Es esto KB legal? Sí, aprende por qué
Licencia bajo: CC-BY-SA with attribution
No afiliado con Stack Overflow
¿Es esto KB legal? Sí, aprende por qué