| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1360 人关注过本帖
标题:一个很怪的VFP小程序
取消只看楼主 加入收藏
wsjzabc
Rank: 1
等 级:新手上路
帖 子:151
专家分:0
注 册:2005-8-6
收藏
 问题点数:0 回复次数:3 
一个很怪的VFP小程序
各位仁兄:
我在编写一个"增加"控件的小程序时,发现如下一个怪怪的小问题:由于数据表mckb以前输入的编号是1,2,3...我仍旧想沿用这种编号顺序,于是编了程序:
SELECT mckb &&选择工作区
OldRecord=RECNO()
GO BOTTOM &&到末记录
LOCAL BH &&声明本地变量来保存编号
BH=alltrim(mckb.number)
APPEND BLANK &&添加新的记录
BH=VAL(BH)+1 &&连结新的字符串,记录编号自动加1

THISFORM.txtnumber.value=BH
thisform.formmode="cadd"
thisform.modemody()
THISFORM.REFRESH()
但是,运行时总是出错.而如果采用前面加上"BH00.."的形式的程序的话,就没有什么错误了:
SELECT mckb &&选择工作区
OldRecord=RECNO()
GO BOTTOM &&到末记录
LOCAL BH &&声明本地变量来保存编号
BH=alltrim(mckb.number)
APPEND BLANK &&添加新的记录
BH=VAL(BH)+1 &&连结新的字符串,记录编号自动加1
IF BH>999
BH=STR(BH,4)
BH="BH"+BH
ELSE
IF BH>99
BH=STR(BH,3)
BH="BH0"+BH
ELSE
IF BH>9
BH=STR(BH,2)
BH="BH00"+BH
ELSE
BH=STR(BH,1)
BH="BH000"+BH
ENDIF
ENDIF
ENDIF
THISFORM.txtnumber.value=BH
thisform.formmode="cadd"
thisform.modemody()
THISFORM.REFRESH()

各位仁兄,若感兴趣的话,可以考虑考虑啊!

搜索更多相关主题的帖子: VFP mckb 变量 
2006-02-27 10:48
wsjzabc
Rank: 1
等 级:新手上路
帖 子:151
专家分:0
注 册:2005-8-6
收藏
得分:0 

首先表示感谢啊.

(1)对你的说明我是这样理解的:把 BH 转换成字符串型后再赋给 TEXT 的 VALUE 值,如下:
SELECT mckb &&选择工作区
OldRecord=RECNO()
GO BOTTOM &&到末记录
LOCAL BH &&声明本地变量来保存编号
BH=alltrim(mckb.number)
APPEND BLANK &&添加新的记录
BH=VAL(BH)+1 &&连结新的字符串,记录编号自动加1
BH=STR(BH)
THISFORM.txtnumber.value=BH
thisform.formmode="cadd"
thisform.modemody()
THISFORM.REFRESH()
但是运行后,THISFORM.txtnumber.value的值仍然不会自动加一.可能是我理解有误吧.
(2)由于我以前录入数据时是按1,2,3...录入的,而且数据很多且分散(不易修改).没有在编号前加000....我只是想让编号自动加一,然后显示在 THISFORM 表单中的 txtnumber 里.
你看怎么办呢? 谢谢!


2006-02-27 16:07
wsjzabc
Rank: 1
等 级:新手上路
帖 子:151
专家分:0
注 册:2005-8-6
收藏
得分:0 
大家有时间过来考虑考虑

2006-03-01 11:58
wsjzabc
Rank: 1
等 级:新手上路
帖 子:151
专家分:0
注 册:2005-8-6
收藏
得分:0 
str()的功能还真没有注意呢.RICES说的起了大作用了,特别感谢啊

2006-03-02 16:04
快速回复:一个很怪的VFP小程序
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017197 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved