Maison >développement back-end >Tutoriel C#.Net >C# DataTable converti en instance d'objet de classe d'entité

C# DataTable converti en instance d'objet de classe d'entité

高洛峰
高洛峰original
2017-01-18 09:34:472289parcourir

public class User 
{ 
        public int ID { get; set; } 
        public string Name { get; set; } 
} 

//对应数据库表: 
//User 
//字段:ID、Name

Ensuite, vous devrez peut-être écrire une méthode pour convertir le DataTable en un objet entité afin de faciliter l'obtention et le remplissage de DataTable.Rows. .

Ce qui suit est une méthode générale que j'ai écrite pour partager l'enregistrement afin de faciliter sa copie à l'avenir ~

private static List<T> TableToEntity<T>(DataTable dt) where T : class,new() 
{ 
    Type type = typeof(T); 
    List<T> list = new List<T>(); 

    foreach (DataRow row in dt.Rows) 
    { 
        PropertyInfo[] pArray = type.GetProperties(); 
        T entity = new T(); 
        foreach (PropertyInfo p in pArray) 
        { 
            if (row[p.Name] is Int64) 
            { 
                p.SetValue(entity, Convert.ToInt32(row[p.Name]), null); 
                continue; 
            } 
            p.SetValue(entity, row[p.Name], null); 
        } 
        list.Add(entity); 
    } 
    return list; 
} 
  
// 调用:
List<User> userList = TableToEntity<User>(YourDataTable);

Pour plus d'articles sur la conversion de DataTable C# en instances d'objet de classe d'entité, veuillez payer attention au site PHP chinois !

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn