看实例学VFP:删除数据表中的记录

本例对看实例学VFP:对数据表中记录进行修改一文的实例进行了一点改进,增加了“撤消”功能。程序运行时如下图:

在组合框中选择要查找的字段,在文本框中输入查找内容后单击右侧的“查找”按钮后将查找结果显示在上方的表格中,“查找”按钮变成“撤消”按钮,同时激活“删除”按钮及用于显示数据的文本框,并将当前记录(满足查询条件的记录)的值同时显示在文本框中,;单击“删除”按钮后会删除查找出来的记录刷新显示并grid1,“删除”按钮的再次被禁用,“撤消”按钮的caption值再次变成“查找”并隐藏显示数据的文本框;单击“撤消”按钮则撤消删除操作并刷新表单。如下图:

关于vfp表记录指针定位和数据排序请参考:记录指针定位和数据排序,关于记录的删除请参考表的操作 (二),本例用到了“数据1”数据库中的“网站信息表”,关于该数据库的情况已经在看实例学VFP:示例数据库一文中给出,这里均不再详述,只简要介绍一下制作过程。

制作步骤如下:

一、新建表单form1,并将其caption属性设置为“删除数据表中的记录”,width属性值设为290,height属性值设为220,AutoCenter属性值设为.t.,并将其保存为“删除数据表中的记录.scx”。

二、向表单添加一个grid控件,将其readonly属性设置为.t.,其RecordSourceType值采用默认的“1-别名”,在表单设计器中将其宽和高粗略调小一些即可,具体属性值我们将在表单的init事件代码中对其进行设置。

三、在grid控件下方添加两个Label控件,使其排成一行,并将其caption属性依次设为“请选择查找方式”和“请输入要查找的内容”。

四、在label控件下方添加一个组合框控件Combo1及一个文本框控件Text1,文本框控件的属性值采用默认即可,组合框控件Combo1的RowSourceType属性值设置为“1-值”,RowSource属性值设置为“编号,网站名称,网站网址”,这样在运行时我们可以在该组合框中选择要查询的字段。

五、在表单上添加两个命令按钮command1和command2,将其caption属性依次设为“查找”和“删除”。

六、在命令按钮下方添加三个label控件,将这三个label控件排成一行,并将其caption属性依次设置为“编号”、“网站名称”和“网站网址”。

七、在这一行label控件下方添加三个文本框控件,属性值采用默认,并把这三个文本框排成一行。

八、调整表单上各个控件的位置,调整后的表单设计器如下图:

九、添加事件代码:

(一)表单的unload事件代码:

set exact off
close data

(二)表单的init事件代码:

set exact on
set delete off
set safe off
this.command2.enabled=.f.
this.Text2.visible=.f.
this.Text3.visible=.f.
this.Text4.visible=.f.
this.Label3.visible=.f.
this.label4.visible=.f.
this.Label5.visible=.f.
use 网站信息表
this.Combo1.value="编号"
with thisform.grid1
  .width=350
  .height=100
  .left=0
  .top=0
  .recordsource="网站信息表"
  .deletemark=.f.
  .visible=.t.
  .readonly=.t.
  .ColumnCount=3
  .Column1.Header1.Caption="编号"
  .Column1.Header1.BackColor=RGB(255,255,190)
  .Column2.Header1.BackColor=RGB(255,255,190)
  .Column2.Header1.Caption="网站名称"
  .Column3.Header1.BackColor=RGB(255,255,190)
  .Column3.Header1.Caption="网站网址"
  .Column1.width=75
  .Column2.width=80
  .Column3.width=150
endwith
this.grid1.Setall("DynamicBackColor","RGB(224,225,255)","Column")

(三)“查找”按钮(command1)的click事件代码:

if this.caption="查找"
 if empty(thisform.Text1.value)=.f.
 go top
 a=thisform.Combo1.value
 b=alltrim(thisform.Text1.value)
 c=.f.
  if a="编号"
     locate for 编号=b
     if eof()
        messagebox("数据库中不存在您所要查询的记录",16,"系统提示")
        go top
        return
      else
       c=.t.
     endif
  endif
  if a="网站名称"
     locate for 网站名称=b
     if eof()
        messagebox("数据库中不存在您所要查询的记录",16,"系统提示")
        go top
        return
     else
        c=.t.
     endif
  endif
  if a="网站网址"
     locate for 网站网址=b
     if eof()
        messagebox("数据库中不存在您所要查询的记录",16,"系统提示")
        go top
        return
     else
        c=.t.
     endif
  endif
  if c
     go recno()
     thisform.Text1.enabled=.f.
     thisform.Text2.visible=.t.
     thisform.Text3.visible=.t.
     thisform.Text4.visible=.t.
     thisform.Text2.enabled=.f.
     thisform.Text3.enabled=.f.
     thisform.Text4.enabled=.f.
     thisform.Label3.visible=.t.
     thisform.label4.visible=.t.
     thisform.Label5.visible=.t.
     thisform.Text2.value=网站信息表.编号
     thisform.Text3.value=网站信息表.网站名称
     thisform.Text4.value=网站信息表.网站网址
     thisform.grid1.setfocus
     this.caption="撤消"
     thisform.command2.enabled=.t.
  endif
 else
   messagebox("请输入要查找的内容!",16,"系统提示")
   thisform.Text1.value=""
   thisform.Text1.Setfocus
 endif
else
 thisform.Text1.enabled=.t.
 thisform.Text2.visible=.f.
 thisform.Text3.visible=.f.
 thisform.Text4.visible=.f.
 thisform.Text2.enabled=.f.
 thisform.Text3.enabled=.f.
 thisform.Text4.enabled=.f.
 thisform.Label3.visible=.f.
 thisform.label4.visible=.f.
 thisform.Label5.visible=.f.
 thisform.Text2.value=""
 thisform.Text3.value=""
 thisform.Text4.value=""
 thisform.grid1.setfocus
 this.caption="查找"
 thisform.command2.enabled=.f.
 go top
 thisform.grid1.setfocus
 thisform.Text1.value=""
 thisform.Text1.Setfocus
endif
thisform.refresh

(四)“删除”按钮(command2)的click事件代码:

msg=messagebox('您确定要删除这条记录吗?',32+4,'系统提示')
if msg=6
   delete
   copy to temp.dbf for not deleted()
   zap
   Append from temp.dbf
   delete file temp.dbf
   messagebox("删除记录成功",16,"系统提示")
   go top
   thisform.grid1.refresh
   thisform.command1.caption="查找"
   this.enabled=.f.
   thisform.Text2.visible=.f.
   thisform.Text3.visible=.f.
   thisform.Text4.visible=.f.
   thisform.Label3.visible=.f.
   thisform.label4.visible=.f.
   thisform.Label5.visible=.f.
   thisform.Text1.enabled=.t.
   thisform.Text1.value=""
   thisform.Text1.setfocus
   thisform.refresh
endif

十、运行“删除数据表中的记录.scx”。

参考资料:

vfp基础教程:http://bianceng.cnhttp://www.bianceng.cn/vfpjc/index0.htm

vfp初级教程:http://bianceng.cnhttp://www.bianceng.cn/cc/index.htm

vfp中级教程:http://bianceng.cnhttp://www.bianceng.cn/mcc/mcc.htm

vfp高级教程:http://bianceng.cnhttp://www.bianceng.cn/hcc/hcc.htm

VFP网络开发:http://bianceng.cnhttp://www.bianceng.cn/VFPwz/vfpwlkf.htm

vfp调用api函数:http://bianceng.cnhttp://www.bianceng.cn/VFPwz/vfpapi.htm

VFP报表打印:http://bianceng.cnhttp://www.bianceng.cn/VFPwz/vfpreport.htm

VFP常用技术:http://bianceng.cnhttp://www.bianceng.cn/VFPwz/vfpcyjs.htm

VFP经验汇总:http://bianceng.cnhttp://www.bianceng.cn/VFPwz/vfpjyhz.htm

VFP控件使用:http://bianceng.cnhttp://www.bianceng.cn/VFPwz/vfpkjsy.htm

VFP数据处理:http://bianceng.cnhttp://www.bianceng.cn/VFPwz/vfpsjcl.htm

本例代码在Win2003+VFP6.0环境下调试通过。

查看全套“菜鸟也学VFP”教程

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索visiblity
, 控件
, text
, 网站
, 属性
, enabled
, setfocus
visible
,以便于您获取更多的相关知识。

时间: 2024-11-17 01:44:49

看实例学VFP:删除数据表中的记录的相关文章

如何有条件的分步删除数据表中的记录

数据|条件 如何有条件的分步删除数据表中的记录作者:eygle出处:http://blog.eygle.com日期:February 22, 2005« 自己动手,丰衣足食 | Blog首页 有时候我们需要分配删除数据表的一些记录,分批提交以减少对于Undo的使用,本文提供一个简单的存储过程用于实现该逻辑.你可以根据你的需要进行适当调整,本例仅供参考: SQL> create table test as select * from dba_objects;Table created.SQL>

看实例学VFP:顶层表单(父子表单)的例子

记得以前有朋友想让他的vfp程序运行时是这个样子:没有VFP的主屏幕(_screen),运行时直接在桌面出现一个登录对话框,输入用户名及密码并验证通过之后出现软件的主界面,看起来象是用VB编写的软件,有种很酷的感觉. VFP软件主界面的实现通常可以采用两种方式:主屏幕(_screen)或顶层表单(或者叫父子表单).可以用顶层表单来实现上述的想法. VFP中设置顶层表单的方法是将表单的showWindow属性设置为"2-作为顶层表单",这也就是所谓的"父表单"了:与之

Sql Server里删除数据表中重复记录的例子_MsSql

[项目] 数据库中users表,包含u_name,u_pwd两个字段,其中u_name存在重复项,现在要实现把重复的项删除! [分析] 1.生成一张临时表new_users,表结构与users表一样: 2.对users表按id做一个循环,每从users表中读出一个条记录,判断new_users中是否存在有相同的u_name,如果没有,则把它插入新表:如果已经有了相同的项,则忽略此条记录: 3.把users表改为其它的名称,把new_users表改名为users,实现我们的需要. [程序] 复制代

Sql Server里删除数据表中重复记录的例子

[项目] 数据库中users表,包含u_name,u_pwd两个字段,其中u_name存在重复项,现在要实现把重复的项删除! [分析] 1.生成一张临时表new_users,表结构与users表一样: 2.对users表按id做一个循环,每从users表中读出一个条记录,判断new_users中是否存在有相同的u_name,如果没有,则把它插入新表:如果已经有了相同的项,则忽略此条记录: 3.把users表改为其它的名称,把new_users表改名为users,实现我们的需要. [程序] 复制代

看实例学VFP:制作只能从顶层表单调用的系统主菜单

我们知道正常的VFP菜单都是显示在主屏幕(_screen)中的,但如果要使用顶层表单来做软件的主界面,_screen是要屏蔽掉的.这就产生了一个问题:_screen没有了,软件菜单该往哪里放呢?没有关系,可以使用只能从顶层表单中调用的菜单来解决这个问题,另外这种菜单的调用处是在顶层表单的init事件中,而不是在主程序中. 本例来制作一个只能从顶层表单调用的系统主菜单MAIN.MPR,下一课我们将会给出使用顶层表单制作软件主界面的示例,并会在该示例中调用这个菜单.该菜单包括"数据操作"和

看实例学VFP:主程序及连编综合示例

本文给出一个简单的主程序并将我们做的这个简单的系统连编成为可执行文件.本实例采用顶层表单作为软件的主界面,运行连编后的exe会首先出现要求用户名和密码的登录表单,如下图: 连续3次输入错误的用户名及密码会自动退出,输入正确的用户名及密码后,登录表单隐藏并且启动主表单,如下图: 本例要点:因为使用顶层表单做主界面,就需要在主程序中加一句_screen.visible=.f.把主屏幕屏蔽掉:主表单是顶层表单,则主表单菜单各模块所调用的表单的ShowWindow属性值都应设置为"1-在顶层表单中&qu

看实例学VFP:向数据表中添加记录时自动生成编号

本例在"看实例学VFP:向数据表中添加记录并验证输入数据是否合法"的基础上进行了改进,实现了在添加记录时不仅能够完成对输入数据的校验,还具有自动生成编号的功能.自动生成编号的相关代码加在表单的init事件及"添加"按钮的click中,在表单第一次启动或添加完记录后都会调用此段代码,实现自动生成编号的功能.运行界面如下: 本例用到了"数据1"数据库中的"网站信息表",关于该数据库的情况已经在看实例学VFP:示例数据库一文中给出,

看实例学VFP:对数据表中记录进行修改

本例运行时表单上用于接收数据的文本框被隐藏,"修改"按钮禁用,如下图: 在组合框中选择要查找的字段,在文本框中输入查找内容后单击右侧的"查找"按钮后将查找结果显示在上方的表格中,"查找"按钮被禁用,同时激活"修改"按钮及用于接收数据的文本框,并将当前记录(满足查询条件的记录)的值同时显示在文本框中,如下图: 单击"修改"按钮后会对输入的值做判断,如果满足非空的条件,则用表单文本框中的值修改"网站信

看实例学VFP:向数据表中添加记录并验证输入数据是否合法

本例的执行过程大致是在添加记录时首先使用empty()函数对接收数据文本框作是否为空的判断,使用locate做记录指针定位(关于vfp表记录指针定位和数据排序请参考:记录指针定位和数据排序),并判断是否和表中已有的数据重复.通过以上方式完成数据校验,如果满足非空.非重复的条件,则使用append blank命令在表中添加一条空白记录,然后使用replace命令将该记录的对应字段的值修改成表单上对应文本框内输入的值.程序运行时如下图: 本例用到了"数据1"数据库中的"网站信息表