如何在应用程序中修改FOXPRO数据表
来源:计算机世界日报 作者:程建平 出处:综艺读书 2005-11-29·FOXPRO常用编程命令及常用函数
·如何修复被破坏的Foxpro数据库
·Foxpro中DDE类函数的应用
·为FoxPro中的弹出式菜单增加自学习功能
·读取foxpro格式的dbf文件
·FOXPRO 系统指标
·Foxpro 更多对象
·foxpro 让视图与数据源相连
·导出EXCEL/FOXPRO/PRODOX格式表
·Foxpro 更多方法
P>早期有不少用FOXPRO编写的数据库应用程序喜欢用6位字符型字段来记录日期。随着2000年的到来,这个字段的宽度显然已经不适用了,需要修改。
·如何修复被破坏的Foxpro数据库
·Foxpro中DDE类函数的应用
·为FoxPro中的弹出式菜单增加自学习功能
·读取foxpro格式的dbf文件
·FOXPRO 系统指标
·Foxpro 更多对象
·foxpro 让视图与数据源相连
·导出EXCEL/FOXPRO/PRODOX格式表
·Foxpro 更多方法
修改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进入讨论组讨论。
相关图文阅读
频道图文推荐
相关专题
最新技术文档
·用FoxWeb在网上快速发布你的FOXPRO数据库 11-03
·用Foxpro制作Windows输入法码表 11-03
·用FoxPro生成HTML文件 11-03
·下载和上载远程视图数据 10-30
·为Visual FoxPro应用程序增加文件压缩功能 10-30
·为VFP添加循环微调控件类 10-30
·为FoxPro中的弹出式菜单增加自学习功能 10-30
·通过编程运行拨号网络连接 10-29
·谈谈在基于Foxpro的MIS中实现提示、帮助与询问 10-29
·谈谈VFP和SQL SERVER搭配做C/S系统 10-29
·用Foxpro制作Windows输入法码表 11-03
·用FoxPro生成HTML文件 11-03
·下载和上载远程视图数据 10-30
·为Visual FoxPro应用程序增加文件压缩功能 10-30
·为VFP添加循环微调控件类 10-30
·为FoxPro中的弹出式菜单增加自学习功能 10-30
·通过编程运行拨号网络连接 10-29
·谈谈在基于Foxpro的MIS中实现提示、帮助与询问 10-29
·谈谈VFP和SQL SERVER搭配做C/S系统 10-29
站内各频道最新更新文档
站内最新制作专题
|
|||
| ·ACDSEE专题教程-下载使用 ·迅雷专题教程-下载使用 ·Windows XP频道 ·Windows Vista频道 ·Windows 2000频道 ·win2003频道 ·Freebsd频道 ·Oracle频道 |
·Linux频道 ·Windows频道 ·邮件服务器专题 ·协议大全 ·数据恢复指南教程 ·FreeBSD使用教程 ·Linux数据库宝典 ·Linux基础知识 |
||
热门关键字导读
站内频道文章精选
| · 秘密:Vista隐蔽的动态屏保 · 腾讯开发新电子宠物--QQ熊 · 惠普否认2999元PC有价无货 |
· 驱逐Win系统“流氓”文件 · WinXP中获取未使用的IP地址 · 尝试format C:格式化硬盘? |
| · 在DOS下恢复回收站中的文件 · 拯救WinXP崩溃的救命稻草 · Linux系统中超级权限的应用 |
· 搜狗PK谷歌:谁能代言拼... · 昨日重现,一键GHOST轻松.. · 实现Web迅雷在空闲时杀毒 |
| · AVIFile函数制做AVI文件 · VC中链接动态链接库的方法 · 熊猫烧香核心源码(Delphi) |
· DateDiff函数祥解 · JavaScript去除空格的三种 · js效果 图片加载进度实时.. |
| · SQL Server数据库优化方案 · Oracle的初学者入门心得 · JSP连接Mysql数据库 |
· Photoshop为美女做艺术处理 · 用Freehand创建发光字特效 · 设计自己的个性QQ动态表情 |
百度推荐,商机无限
搜索您感兴趣的内容




