Attribute(特性),怎么用才更好? —— 字段编号被误解了
2010-08-06 13:00
197 查看
上一篇里(Attribute(特性),怎么用才更好? ),有人说,“坚决杜绝magic number ”,这个magic number指的就是字段编号吧,其实您误解了。
一提到字段编号,可能有些人的第一反应就是这样的用法:
Person1.2000020,或者Person1[2000020],或者ds[2000020]。
这么用确实是不好的,不易读,很容易写错。但是我可没说要这么用呀。请看实体类的定义,可能是写在后面了,有些人没仔细看吧。
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表)里的主键字段值,见下图。
用关联的方式,记录表单里需要哪些字段,下图是一个视图
上一篇的回复比较多,直接回复的话,恐怕好多人看不到。而我觉得好像好多人都有这种误解,所以还是单开一篇来说明一下。
一提到字段编号,可能有些人的第一反应就是这样的用法:
Person1.2000020,或者Person1[2000020],或者ds[2000020]。
这么用确实是不好的,不易读,很容易写错。但是我可没说要这么用呀。请看实体类的定义,可能是写在后面了,有些人没仔细看吧。
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表)里的主键字段值,见下图。
用关联的方式,记录表单里需要哪些字段,下图是一个视图
上一篇的回复比较多,直接回复的话,恐怕好多人看不到。而我觉得好像好多人都有这种误解,所以还是单开一篇来说明一下。
相关文章推荐
- Attribute(特性),怎么用才更好? —— 字段编号被误解了
- Attribute(特性),怎么用才更好?
- Attribute(特性),怎么用才更好?
- 基础知识备忘——字段(Field),属性(Property),特性(Attribute)
- C#,什么是Attribute?什么特性?怎么被调用?
- 如何让SELECT 查询结果额外增加自动递增序号 如果数据表本身并不内含自动递增编号的字段时,要怎么做才能够让SELECT查询结果额外增加自动递增序号呢?下列五种方法供您参考: USE test;
- 自动编号的字段怎么让他重新从1开始编号
- asp.net 利用特性和正则表达式进行字段的验证(attribute)
- sqlserver怎么给已有表的已有字段添加自动编号
- C# 入门(19) 反射(reflection)和特性(attribute)
- oracle数据库怎么存储长文本的字段
- SQL语句怎么去掉字段不想要的字符?
- 当你有1000甚至更多字段要更新数据库,怎么办?看我的
- 请问大家 刚开始学习sql 请问我已经建立了几个字段,怎么用sql修改 这几个字段的属性呢?
- Unity 特性(Attribute)总览
- Access数据库“自动编号”字段归零
- Oracle中查询某字段不为空或者为空的SQL语句怎么写
- Attribute鲜为人知的两个特性记录
- oracle中,怎么根据字段名称,搜索的某个表的某个字段
- 怎么给HyperLinkColumn的DataNavigateUrlField指定多个字段?