前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Attribute(特性),怎么用才更好? —— 字段编号被误解了

Attribute(特性),怎么用才更好? —— 字段编号被误解了

作者头像
用户1174620
发布2018-02-26 17:08:04
5670
发布2018-02-26 17:08:04
举报

  上一篇里(Attribute(特性),怎么用才更好? ),有人说,“坚决杜绝magic number ”,这个magic number指的就是字段编号吧,其实您误解了。

  一提到字段编号,可能有些人的第一反应就是这样的用法:

  Person1.2000020,或者Person1[2000020],或者ds[2000020]。

  这么用确实是不好的,不易读,很容易写错。但是我可没说要这么用呀。请看实体类的定义,可能是写在后面了,有些人没仔细看吧。

代码语言:javascript
复制
public class Person
    {
        private string _Name;
        private int _Age;
        private string _Sex;
        [ColumnID(2000020)]
        public string Name
        {
            get { return this._Name; }
            set { this._Name = value; }
        }
        [ColumnID(2000040)]
        public int Age
        {
            get { return this._Age; }
            set { this._Age = value; }
        }
        [ColumnID(2000030)]
        public string Sex
        {
            get { return this._Sex; }
            set { this._Sex = value; }
        }
    }

那么用的时候是什么样的呢?和普通的实体类没什么区别,就是 Person1.Name、Person1.Age。没有magic number什么事。

那么magic number 在什么时候用呢?在保存数据的时候才需要用的。

我们写一个通用的函数实现保存数据的功能,在这里通过反射获得字段编号,然后根据编号到数据库里提取需要的信息。

这个过程并不需要程序员操心,而且也没有具体的某个字段编号。

所以我觉得完全不存在magic number 的缺点。这里的字段编号完全是给程序看的,而不是给程序员看的

字段编号 != 字段名称

字段编号其实是字段描述表(Manage_Columns表)里的主键字段值,见下图。

用关联的方式,记录表单里需要哪些字段,下图是一个视图

上一篇的回复比较多,直接回复的话,恐怕好多人看不到。而我觉得好像好多人都有这种误解,所以还是单开一篇来说明一下。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2010-08-06 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档