ArgumentException sur PropertyInfo.SetValue () dans .Net Compact

.net c# compact-framework dapper dapper-lite

Question

J'utilise DapperLite , un port de Dapper , pour une utilisation dans Compact Framework. Je reçois une exception ArgumentException , aucune autre information dans la méthode ci-dessous à la ligne spécifiée du fichier SqlMapper.cs .

Vraiment mal avec quoi chercher ensuite ou ce qui est réellement cassé.

/// <summary>
    /// Populate a references type from an IDataRecord by matching column names to property names.
    /// </summary>
    private static void PopulateClass(object objectClass, IDataRecord reader)
    {
        Type theType = objectClass.GetType();
        PropertyInfo[] p = theType.GetProperties();


        // Only set properties which match column names in the result.
        foreach (string columnName in GetColumnNames(reader))
        {
            string colName = columnName;
            object value = reader[colName];
            PropertyInfo pi = p.FirstOrDefault(x => x.Name == colName);


            if (pi == null || value == DBNull.Value) continue;


            Type columnType = value.GetType();
            Type actualType = Nullable.GetUnderlyingType(pi.PropertyType) ?? pi.PropertyType;


            // Check for a directly assignable type
            if (actualType == columnType || actualType == typeof(string) || actualType == typeof(int))
            {
                // Error generated here
                pi.SetValue(objectClass, value, null);
            }
            else
            {
                value = actualType.GetMethod("Parse", new[] { typeof(string) }).Invoke(null, new[] { value });
                pi.SetValue(objectClass, value, null);
            }
        }
    }

Les valeurs à ce stade sont objectClass = Models.Employee et value=1 . Le colName , de plus haut dans la méthode, est Id qui est un int dans le modèle Employee .


Modèle d'employé ajouté basé sur le commentaire:

namespace BioPadPunchClock.Models
{
    public class Employee
    {
        public int Id { get; set; }
        public int CDB_Employee_PK { get; set; }  //Employee PK in the Central DB. If .null., new emp record on this timeclock needs to be pushed to the CDB.
        public string Name { get; set; }
        //public string FaceImage { get; set; }  //path to Jpeg image 136x90 pixels .\NAND\pictures\  named as <pk>.jpg
        public DateTime? BirthDate { get; set; }
        public string Status { get; set; }  //Full Time – Hourly, Inactive, Terminated, Part Time - Hourly  
        public DateTime? LastPunch { get; set; }
        public string LastPunchDirection { get; set; }  //IN or OUT
        public string PIN { get; set; }  // 4 digit
        public int CardNum { get; set; }  //HID Card Number
        public int CardFacCode { get; set; }  //HID Card Facility Code
        public string FpTemplate { get; set; }  //Fingerprint Template (registered fingerprint)
        public DateTime? LastUpdate { get; set; }  //When this employee record was last sync’d to the CDB. This value will match exactly in the LDB and CDB after a successful sync.
        public int DayTotal { get; set; } // Minutes cumulative for the current day at time of last punch
        public int PayPeriodTotal { get; set; } //Minutes cumulative for the current pay period at time of last punch
        public string Department { get; set; }
        public string SSN { get; set; }
        public bool ShouldPromptDept { get; set; } //Prompt employee to choose department each time
    }
}

Autres conclusions ...

Lorsque je regarde mon Model.Employee à ce stade, toutes les propriétés de la string indiquent Could not evaluate expression avec un point d’exclamation rouge. Est-ce un indice ou normal?


Autres conclusions ...

Je ne suis pas sûr que cela soit important ou pas, mais quand je passe en actualType == Int32 le code et inspecte les valeurs, je remarque que le type actualType == Int32 et le columnType==Int64 tandis que la value qu’il évalue est 1 .

Je ne suis pas sûr que cela fasse une différence car il y a un actualType.Equals(typeof(int)) mais je pensais le mentionner.

Réponse acceptée

Nous avons compris cela sur GitHub avec le dernier élément d'information.

Etant donné que columnType est Int64 pour la colonne Id , la modification du type de la colonne Id dans le modèle en Int64 ce problème.




Sous licence: CC-BY-SA with attribution
Non affilié à Stack Overflow
Est-ce KB légal? Oui, apprenez pourquoi
Sous licence: CC-BY-SA with attribution
Non affilié à Stack Overflow
Est-ce KB légal? Oui, apprenez pourquoi