利用反射执行代码

项目组经常有用到反射来执行代码的,直接上代码,大家一看就明白。

复制代码
    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);
                }
            }
        }
复制代码

输出结果:

 

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

posted on   jack_Meng  阅读(364)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?

导航

< 2025年3月 >
23 24 25 26 27 28 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 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示

喜欢请打赏

扫描二维码打赏

支付宝打赏

主题色彩