zoukankan      html  css  js  c++  java
  • asp.net DataReader DataTable 使用反射给给实体赋值

    asp.net 使用反射给给实体赋值 

     实体类继承此基类

    using System.Reflection;
    using System.Data.SqlClient;
    using System.Data;
    namespace Model
    {
        public class Base
        {
            protected bool isNull = true;
            public bool IsNull
            {
                get { return isNull; }
                set { isNull = value; }
            }
            protected void SetValue(object info)
            {
                foreach (FieldInfo fi in info.GetType().GetFields(BindingFlags.NonPublic | BindingFlags.Instance))
                {
                    fi.SetValue(this, fi.GetValue(info));
                }
            }
            public void SetValue(SqlDataReader dr)
            {
                if (dr.Read())
                {
                    foreach (FieldInfo fi in this.GetType().GetFields(BindingFlags.NonPublic | BindingFlags.Instance))
                    {
                        if (fi.Name != "isNull")
                        {
                            fi.SetValue(this, dr[fi.Name]);
                        }
                    }
                    this.isNull = false;
                }
                dr.Close();
            }
    
            public void SetValue(DataTable dt)
            {
                if (dt != null && dt.Rows.Count > 0)
                {     
                    foreach (DataRow row in dt.Rows)
                    {
                        foreach (DataColumn column in dt.Columns)
                        {
                            FieldInfo fi = this.GetType().GetField(column.ColumnName);
                            if (fi.Name != "isNull")
                            {
                                fi.SetValue(this, row[fi.Name]);
                            }
                        } 
                    } 
                }
            }
    
        }
    }
    View Code

     实体类

    namespace Model
    {
        public class Users: Base
        {
            protected String userid;
            public String UserId
            {
                get { return userid; }
                set { userid= value; }
            }
            protected String username;
            public String UserName
            {
                get { return username; }
                set { username= value; }
            }
        }
    }
    View Code

    给实体类赋值

      public Users Get(String username)
            {
                Users info = new Users ();
                SqlParameter[] paras ={
                               new SqlParameter("@username",SqlDbType.NVarChar)
                                };
                paras[0].Value = username;
                SqlDataReader dr = DbHelper.ExecuteReader(CommandType.StoredProcedure, "GetUsersByUserName", paras);
                info.SetValue(dr);
                return info;
            }
    View Code
  • 相关阅读:
    数论笔记
    哈哈哈
    闭关修炼屯题中,期末考完A
    acm几何
    POJ
    Educational Codeforces Round 42 (Rated for Div. 2) D.Merge Equals (优先队列)
    Educational Codeforces Round 42 (Rated for Div. 2) C. Make a Square (dfs)
    牛客网 VVQ 与线段 (优先队列或线段树或RMQ)
    Educational Codeforces Round 41 (Rated for Div. 2) C.Chessboard (DP)
    Educational Codeforces Round 41 (Rated for Div. 2)D. Pair Of Lines
  • 原文地址:https://www.cnblogs.com/yonsy/p/4385938.html
Copyright © 2011-2022 走看看