千年虫问题解决一例


谖业ノ焕镉肍oxPro2.5开发的管理系统中,其日期字段大多是以宽度为8位,类型为Character(字符型)、格式为“月/日/年”的方式来表示的,其中年份的长度为2位,如1997年8月20日的格式为“08/20/97”,由于字段是字符型,且年份只有2位数, 所以在作跨世纪的日期运算时会因软件不能区分“00”究竟是代表1900年还是2000年而产生混乱(这一点已经在模拟实验中得到证实)。解决办法便是必须找出这些字段将其宽度修改为10位并将年份的前二位数字加上才行。我所编译的程序的工作原理是首先查找类型为Character型,长度为8位的字段,再测试记录内容中是否含有2个或2个以上的“/”号。如果条件全满足,则可肯定这是个有“2000问题”的日期字段。以下是2000.PRG程序源代码。
SET TALK OFF
CLOSE ALL
SET COLO TO W+/B
CLEA
SELE 2
USE 2000 &&打开存放有2000问题数据库资料的库
DELE ALL
PACK &&删除其中的内容
SELE 1
ML=SPACE(50)
@ 6, 8 SAY 请输入目录(全名): GET ML;
MESSAGE “如A:\DBF,直接回车退出”
READ
IF ML=“” &&目录路径为空则退出
CLEA
RETU
ENDI
ML=ALLTRIM(ML) &&删除路径的左右空格
KZM=“DBF” &&默认数据库的扩展名为DBF
@ 8,4 SAY “请输入数据库的扩展名: ”GET KZM;
MESSAGE “默认值为DBF”
READ
@ 24,0
KZM=ALLTRIM(KZM) &&删除扩展名的左右空格
@ 12,24 SAY“正在查找,请稍候……”= ADIR(MYARRAY, ALLTRIM(ML)+\*.+KZM) &&将该目录下的DBF文件组成数组
FOR I = 1 to ALEN(MYARRAY)/5
FILENAME = ALLTRIM(ML)+\+MYARRAY(I, 1) &&读取第一列的数据库名称
USE &FILENAME &&打开第一列的数据库
=AFIELDS(ABC) &&将数据库的字段放入数组ABC中
A=ALEN(ABC,1) &&求数组ABC中字段的列数
FOR II=1 to A
IF ABC(II,3)=8.and.ABC(II,2)=C &&如果字段长度为8且类型为字符型C
ZD=ABC(II,1) &&读取字段名称内容
SELE 1
GO TOP
NR=&ZD
IF OCCURS(/,NR)$#@62;=2 &&如果记录内容中有2个以上的/号
SELE 2 &&进入资料库
APPEND BL
REPL FILE WITH FILENAME &&替代DBF文件名称
REPL FIELD WITH ABC(II,1) &&替代字段名称
REPL TYPE WITH ABC(II,2) &&替代字段类型
REPL LEN WITH ABC(II,3) &&替代字段长度
ENDI
ENDI
ENDF
SELE 1
ENDF
CLOSE ALL
@ 2,70
WAIT WINDOWS “查找完成,请打开2000.DBF数据库查看结果,按任意键退出”
CLEA
RETU
TEXT

2000.DBF是存放有2000年问题数据库,结构如下:
Structure for database: C:0000.DBF
Number of data records: 4
Date of last update : 02/09/99
Code Page : 0
Field Field Name Type Width Dec Index Collate
1 FILE Character 50 &&有2000年问题的数据库名称(含路径)
2 FIELD Character 10 &&有2000年问题的数据库字段
3 TYPE Character 1 &&该字段的类型
4 LEN Numeric 3 &&该字段的长度** Total ** 65

Published At
Categories with 数据库类
Tagged with
comments powered by Disqus