转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 软件使用 >> 常用软件 >> 正文
如何在应用程序中修改FOXPRO数据表         

如何在应用程序中修改FOXPRO数据表

作者:闵涛 文章来源:闵涛的学习笔记 点击数:754 更新时间:2009/4/24 21:43:30
P>早期有不少用FOXPRO编写的数据库应用程序喜欢用6位字符型字段来记录日期。随着2000年的到来,这个字段的宽度显然已经不适用了,需要修改。

  修改FOXPRO数据表结构,常用MODIFY STRUCTURE命令。这种方法虽然方便,但必须在人机对话中实现。若您的程序已交付许多用户使用,要求用户采用MODIFY STRUCTURE命令修改数据表结构势必会带来许多麻烦。是否可通过执行预先编制好的程序来完成扩大字段宽度工作?笔者最近做了一个尝试,其程序思路是:

  1、利用AFIELDS()函数获取要修改的数据表结构信息,并将信息存放在STR_FIL数组内。AFIELDS()函数的语法:AFIELDS(ArrayName),ArrayName是放置表结构信息的数组名(可由自己命名,本例中命名为STR_FIL),数组为每一个字段创建一行数据,其每一列里存储的信息如下:

列号 字段信息 数据类型 1 字段名 字符型 2 字段类型 字符型 3 字段宽度 数值型 4 小数点位置 数值型 5 容许的空值 逻辑型 6 字段有效准则 字符型 7 字段有效文本 字符型 8 字段缺省值 字符型 9 表有效准则 字符型 10 表有效文本 字符型

  2、根据要求修改STR_FIL数组内容(本例,修改字段宽度)。

  3、利用CREATE CURSOR 命令,按STR_FIL数组内容创建一临时表结构。

  4、将原表数据添加到临时表中。

  5、利用COPY TO 命令,将临时表覆盖原表。

  下面是修改字段宽度的原代码:

*参数:SOU_FILE(修改的数据表文件名),字符型
*参数:FIE_NAME(要修改的字段名),字符型
*参数:FIE_   (修改后的字段宽度),数字型
PARA SOU_FILE,FIE_NAME,FIE_WID
PRIV STR_FIL,FIEL_SUM,N, STR_TMP
IF USED(“&SOU_FILE”) 
&&打开要修改的数据表
 SELE &SOU_FILE
ELSE
 SELE 0
 USE &SOU_FILE
ENDIF
=AFIELDS(STR_FIL) 
 &&获取表结构,并存储在STR_FIL数组内
FIEL_SUM=FCOUNT() &&计算表字段数
N=1
DO WHILE N$#@60;=FIEL_SUM 
 &&查找要修改的字段名
	IF ALLT(STR_FIL(N,1))=FIE_NAME 
&&如果是要修改的字段名
	 IF STR_FIL(N,3)=FIE_WID 
&&判别字段宽度是否相同
	 RETURN 
 &&相同返回
	 ELSE 
 &&否则修改表结构
 wait "正在修改数据结构,
请稍侯..." WIND NOWAIT 
 	 STR_FIL(N,3)=FIE_WID 
 &&确定字段长度
	 EXIT &&退出循环
 IF N= FIEL_SUM &&如果循环结束
 wait "无修改的字段,按任意键返回….
" WIND &&提示用户
 RETURN
 ENDIF
		ENDIF
	ENDIF
	N=N+1
ENDDO

*按STR_FIL数组内容,创建临时表结构
SELE 0
*根据STR_FIL数组规定的字段名字、
类型、宽度创建临时表STR_TMP
CREATE CURSOR STR_TMP 
FROM ARRAY STR_FIL 
SELE &SOU_FILE
USE &&关闭原数据表

*将原数据表数据添加到临时表STR_TMP中
SELE 0
APPE FROM &SOU_FILE 
COPY TO &SOU_FILE &&复制新的数据原表
RETURN


[办公软件]在sybase中插入图片、PDF、文本文件  [办公软件]安装Sybase ASE
[办公软件]linux指令大全(完整篇)  [办公软件]Linux新手入门常用命令大全
[办公软件]在RedHat Linux 9里安装gaim0.80  [办公软件]浅谈Linux 下Java 1.5 汉字方块问题解决方法
[办公软件]Linux程序员必读:中文化与GB18030标准  [办公软件]linux指令大全
[办公软件]制作Linux启动盘的四种方法  [办公软件]Linux文件系统的反删除方法
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · 办公软件  · 系统软件
    · 常用软件  · 聊天工具
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台