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

简介:   上一篇里(Attribute(特性),怎么用才更好? ),有人说,“坚决杜绝magic number ”,这个magic number指的就是字段编号吧,其实您误解了。   一提到字段编号,可能有些人的第一反应就是这样的用法:     Person1.2000020,或者Person1[2000020],或者ds[2000020]。

 

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

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

 

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

 

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

 

 

img_405b18b4b6584ae338e0f6ecaf736533.gif
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表)里的主键字段值,见下图。

 

 

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

 

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

 

 

 

 

 

相关文章
|
23天前
|
存储 算法 数据库
【C++ 软件设计思路】学习C++中如何生成唯一标识符:从UUID到自定义规则
【C++ 软件设计思路】学习C++中如何生成唯一标识符:从UUID到自定义规则
103 0
|
6月前
|
开发者 C++
【C++11保姆级教程】Type aliases(类型别名)、alignof and alignas(类型对齐))
【C++11保姆级教程】Type aliases(类型别名)、alignof and alignas(类型对齐))
|
7月前
|
存储 XML SQL
浅谈扩展字段设计
浅谈扩展字段设计
211 0
|
10月前
|
人工智能
一文搞懂候选码、主码、全码、外码、主属性、主键、主关键字、非主属性清晰总结
一文搞懂候选码、主码、全码、外码、主属性、主键、主关键字、非主属性清晰总结
|
存储 Java
定义不可变对象的策略---粗略翻译自文档
定义不可变对象的策略---粗略翻译自文档
定义不可变对象的策略---粗略翻译自文档
|
编译器 Scala 开发者
类型匹配的注意事项和细节 | 学习笔记
快速学习类型匹配的注意事项和细节
58 0
|
关系型数据库 MySQL 数据库
数据库技术知识点(一)IDEFO需求建模方法、解释实体、实体型、实体集的区别、完全函数依赖、部分函数依赖、传递函数、平凡函数依赖、非平凡函数依赖举例、超码、主码、候选码的概念与区分
数据库技术知识点(一)IDEFO需求建模方法、解释实体、实体型、实体集的区别、完全函数依赖、部分函数依赖、传递函数、平凡函数依赖、非平凡函数依赖举例、超码、主码、候选码的概念与区分
数据库技术知识点(一)IDEFO需求建模方法、解释实体、实体型、实体集的区别、完全函数依赖、部分函数依赖、传递函数、平凡函数依赖、非平凡函数依赖举例、超码、主码、候选码的概念与区分
|
iOS开发
Objective-C中通过下标的方式访问自定义数据模型中属性
Objective-C中通过下标的方式访问自定义数据模型中属性
131 0
|
Java 编译器 程序员
谈谈C++新标准带来的属性(Attribute)
从C++11开始,标准引入了一个新概念“属性(attribute)”,本文将简单介绍一下目前在C++标准中已经添加的各个属性以及常用属性的具体应用。
谈谈C++新标准带来的属性(Attribute)
|
XML Java 数据格式
Attribute(特性),怎么用才更好?
前几年:   2008年的某一天,我坐火车去北京。硬卧上铺,一晚上就到北京了。爬到上铺之后发现,旁边上铺有一老兄抱着一个笔记本,一开始还以为是看电影呢,仔细一看才发现——老天呀,居然在写代码!     这老兄也太工作狂了,当时可是晚上九点多了呀。
996 0