利用反射執行代碼

項目組常常有用到反射來執行代碼的,直接上代碼,你們一看就明白。app

    public class PrimaryKeyAttribute : Attribute
    { }
    public class DbColumnAttribute : Attribute
    {
        public string Name { get; set; }
        public DbColumnAttribute(string name)
        {
            this.Name = name;
        }
    }
    public class Client
    {
        [PrimaryKey]
        [DbColumn("client_id")]
        public int ClientId { get; set; }

        [DbColumn("last_name")]
        public string LastName { get; set; }

        [DbColumn("first_name")]
        public string FirstName { get; set; }

        [DbColumn("email")]
        public string Email { get; set; }
    }


        static void Test3()
        {
            var client = new Client() { ClientId = 2, LastName = "James", FirstName = "jon", Email = "jon@163.com" };
            WritePK<Client>(client);
            Console.WriteLine();
            WriteColumnMappings<Client>(client);
        }

        public static void WritePK<T>(T item) where T : new()
        {
            var type = item.GetType();
            var queryPts = type.GetProperties();
            Console.WriteLine("Finding PK for {0} ...", type.Name);

            var pk = queryPts.FirstOrDefault(x =>
                        x.GetCustomAttributes(false).Any(
                            a => a.GetType() == typeof(PrimaryKeyAttribute)
                        )
                    );
            if (pk != null)
            {
                string msg = "The Primary Key for the {0} class is the {1} property";
                Console.WriteLine(msg, type.Name, pk.Name);
            }
        }

        public static void WriteColumnMappings<T>(T item) where T : new()
        {
            var type = item.GetType();
            var queryPts = type.GetProperties();
            Console.WriteLine("Finding properties for {0} ...", type.Name);

            foreach (var p in queryPts)
            {
                var attributes = p.GetCustomAttributes(false); //獲取屬性的特性
                var columnMapping = attributes.FirstOrDefault(a =>
                                        a.GetType() == typeof(DbColumnAttribute)
                                    );
                if (columnMapping != null)
                {
                    string msg = "the {0} property maps to the {1} database column";
                    var mapsto = columnMapping as DbColumnAttribute;
                    Console.WriteLine(msg, p.Name, mapsto.Name);
                }
            }
        }

輸出結果:this

 

出處:http://blog.csdn.net/joyhen/article/details/39206427spa

相關文章
相關標籤/搜索