首頁 > 後端開發 > C#.Net教程 > C# DataTable 轉換為 實體類別物件實例

C# DataTable 轉換為 實體類別物件實例

高洛峰
發布: 2017-01-18 09:34:47
原創
2258 人瀏覽過

1

2

3

4

5

6

7

8

9

public class User

{

        public int ID { get; set; }

        public string Name { get; set; }

}

 

//对应数据库表:

//User

//字段:ID、Name

登入後複製

那麼你或許需要寫將DataTable 轉換為實體物件的方法,便利DataTable.Rows 取得並填入。 。

下面是我寫的一個通用方法,分享+記錄,便於日後直接Copy ~

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

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中文網!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板