利用反射读取数据库数据

using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApplication7
{
    public class DBHelper
    {
        private static string ConnectionStringCustomers = ConfigurationManager.ConnectionStrings["connectionstring"].ConnectionString;




        public void Query()
        { }

        public T QueryDomain()
        {
            int OrderID = 2;
            Type type = typeof(T);

            T t = (T)Activator.CreateInstance(type);
            foreach( var a in type.GetProperties())
            {
                Console.WriteLine("11");
            }
            string column = string.Join(",", type.GetProperties().Select(p => string.Format("{0}", p.Name)));


            string sql = string.Format( "select {0} from[{1}] where OrderID={2}",column,type.Name,OrderID);
            using (SqlConnection coon = new SqlConnection(ConnectionStringCustomers))

            {
                SqlCommand sqlcommand = new SqlCommand(sql, coon);
                
                coon.Open();
                SqlDataReader reder=sqlcommand.ExecuteReader(CommandBehavior.CloseConnection);
                if (reder.Read())
                {
                    foreach (var a in type.GetProperties())
                    {
                        string aName = a.Name;
                                               
                        a.SetValue(t, reder[aName]);

                        Console.WriteLine("shuxing{0},zhi:{1}", a.Name,a.GetValue(t));
                    }
                }
            }
            return default(T);
            }


    }
 
   
}

 



  
    
  
  
    
  

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApplication7
{
    class Program
    {
        static void Main(string[] args)
        {
           
           Type type=typeof(Class1);//寻找对象

            object oobject=Activator.CreateInstance(type);//寻找对象

            foreach (var a in type.GetProperties())
            {
                Console.WriteLine("属性名称{0},值是{1}", a.Name, a.GetValue(oobject));
            }
            DBHelper dbhelper = new DBHelper();

            dbhelper.QueryDomain();
            Console.ReadLine();
        }
    }
}

 数据库实体类

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApplication7
{
    class Class1
    {
        public int OrderID { get; set; }

        public string Address { get; set; }

    }
}

转载于:https://www.cnblogs.com/LZXX/p/6706560.html

你可能感兴趣的:(利用反射读取数据库数据)