不重复编号的生成

也许你已经留意到,在表达式生成器中,有一个在表中并未出现的列名:_Identify

_Identify是实实在在存在的列,只是你看不到而已;新增记录的时候,该列的值会自动增量,步长为1,但是该值是临时的,保存的时候,才会生成真正的值。

即使多人同时增加和保存数据的时候,该列的值也是不重复的,这个列类似于Access/Sql Server的自动增量主键,不同的是,多人同时保存的时候,在Foxtable中,每个人得到的编号是连续的,而Access/Sql Server是分散的。

有了_Identify,你可以删除原来的产品编号、客户编号、订单编号等列,新增一个同名的整数型表达式列,表达式设为:

[_Identify]

这样不仅编号可以生成,而且不管有多少人同时向表中增加行,生成的编号都是连续的,而且是不重复的。

副作用是,你永远无法修改编号列的内容,不过从数据安全角度来看,也许这样更好!

提示:

1、只有通过Foxtable创建的数据表才有_Identify列。
2、直接用_Identify作为编号的前提,是你对编号没有特殊的格式要求,否则保留原来的编号列,手工输入编号较好。
3、_Identify列的值一旦生成,就不能修改,所以如果需要手工调整编号,就不能使用_Identify作为编号使用了。


本页地址:http://www.foxtable.com/webhelp/topics/0107.htm