您现在的位置: 中国男护士网 >> 考试频道 >> 计算机等级 >> 二级辅导 >> VFP >> 辅导 >> 正文    
  如何在应用程序中修改FOXPRO数据表 【注册男护士专用博客】          

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

www.nanhushi.com     佚名   不详 

  修改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

 

文章录入:杜斌    责任编辑:杜斌 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
     

    联 系 信 息
    QQ:88236621
    电话:15853773350
    E-Mail:malenurse@163.com
    免费发布招聘信息
    做中国最专业男护士门户网站
    最 新 热 门
    最 新 推 荐
    相 关 文 章
    没有相关文章
    专 题 栏 目

      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)                            【进男护士社区逛逛】
    姓 名:
    * 游客填写  ·注册用户 ·忘记密码
    主 页:

    评 分:
    1分 2分 3分 4分 5分
    评论内容:
  • 请遵守《互联网电子公告服务管理规定》及中华人民共和国其他各项有关法律法规。
  • 严禁发表危害国家安全、损害国家利益、破坏民族团结、破坏国家宗教政策、破坏社会稳定、侮辱、诽谤、教唆、淫秽等内容的评论 。
  • 用户需对自己在使用本站服务过程中的行为承担法律责任(直接或间接导致的)。
  • 本站管理员有权保留或删除评论内容。
  • 评论内容只代表网友个人观点,与本网站立场无关。