ホームページ  >  記事  >  バックエンド開発  >  C# DataTable をエンティティ クラス オブジェクト インスタンスに変換

C# DataTable をエンティティ クラス オブジェクト インスタンスに変換

高洛峰
高洛峰オリジナル
2017-01-18 09:34:472106ブラウズ

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

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

その後、DataTable.Rows が取得して入力できるように、DataTable をエンティティ オブジェクトに変換するメソッドを記述する必要がある場合があります。 。

以下は私が書いた一般的な方法で、共有 + 記録し、将来的には直接コピーしやすいです~

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);

C# DataTable をエンティティ クラス オブジェクト インスタンスに変換することに関するその他の記事については、PHP 中国語 Web サイトに注目してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。