【PB案例学习笔记】-46在数据窗口中编辑数据

大家好,我是晓凡

写在前面

这是PB案例学习笔记系列文章的第46篇,该系列文章适合具有一定PB基础的读者。

通过一个个由浅入深的编程实战案例学习,提高编程技巧,以保证小伙伴们能应付公司的各种开发需求。

文章中设计到的源码,小凡都上传到了gitee代码仓库https://gitee.com/xiezhr/pb-project-example.git

需要源代码的小伙伴们可以自行下载查看,后续文章涉及到的案例代码也都会提交到这个仓库【pb-project-example

如果对小伙伴有所帮助,希望能给一个小星星⭐支持一下小凡。

一、小目标

通过本案例我们将实现在数据窗口中对数据进行增删改查操作。

程序最终效果如下:

二、实现思路

PB中,我们可以通过RowCountInsertRowDeleteRowScrollToRowupdate函数来对数据进行增删改查操作。

2.1 InsertRow函数

在数据窗口控件指定行前面插入一行

语法:

java 复制代码
dwcontrol.InsertRow(row)

参数说明:

参数 说明
dwcontrol 需要操作的数据窗口空间名
row Long类型,指定在哪一行前面插入新行。当row=0时,表示在最后一行后面插入一行
2.2 RowCount函数

返回数据窗口控件当前可用的行数

语法:

java 复制代码
dwcontrol.RowCount()
2.3 ScrollToRow函数

滚动数据窗口控件的显示到指定行,行数改变当前行,但不改变当前列

语法:

java 复制代码
dwcontrol.ScrollToRow(row)
2.4 Update函数

把数据窗口控件中所有数据修改(增、删、改)传送到数据库,从而更新数据库中数据

注:在使用Update函数之前需要先调用AcceptText函数将"漂浮"在当前行/列上的编辑框中的内容放入到数据窗口的缓冲区中

语法:

java 复制代码
dwcontrol.Update({accept{,resetflag}})

参数说明:

参数 参数说明
dwcontrol 数据窗口空间名
accept 可选项,Boolean类型。指定数据窗口控件在更新数据库之前是否自动执行AcceptText的功能呢
resetflag 可选项,Boolean类型,指定更新数据库后是否自动恢复更新标志

三、创建程序基本框架

有了基本思路之后,我们就动起来开始写程序了

① 新建examplework 工作区

② 新建exampleapp应用

③ 新建w_main窗口,并将其Title设置为"窗口中编辑数据"

由于文章篇幅的原因,以上步骤就不再赘述,如果忘记的小伙伴可以翻一翻该系列第一篇文章复习一下

四、界面布局

① 建立数据窗口对象

连接数据库,选择emp表,建立Grid风格的数据窗口,选中需要的字段,并保存为d_emp

② 建立窗口控件

w_main窗口中添加1个DataWindow控件和4个CommandButton控件,依次命名为dw_1cb_1~cb_4

③ 设置窗口控件

  • dw_1DataObject属性设置为d_emp
  • cb_1Text属性设置为"添加"
  • cb_2Text属性设置为"删除"
  • cb_3Text属性设置为"保存"
  • cb_4Text属性设置为"退出"

五、编写代码

① 在w_main窗口的Open事件中添加如下代码

java 复制代码
dw_1.settransobject(sqlca)
dw_1.retrieve()

② 在w_main窗口的cb_1按钮的Clicked事件中添加如下代码

java 复制代码
int li_row
//在数据窗口的最后一行后面插入一行
li_row = dw_1.insertRow(0)
// 滚动到li_row行
dw_1.scrollToRow(li_row)
//设置焦点
dw_1.setfocus()

③ 在w_main窗口的cb_2按钮的Clicked事件中添加如下代码

java 复制代码
int li_row
//获取当前行
li_row = dw_1.getRow()
//删除li_row行
dw_1.deleteRow(li_row)
//将数据更新到数据库
dw_1.update()
//提交事务
commit;
//查询数据赋值给dw_1
dw_1.retrieve()

④ 在w_main窗口的cb_3按钮的Clicked事件中添加如下代码

java 复制代码
//将数据更新到数据库
dw_1.update()
//提交事务
commit;
//查询数据赋值给dw_1
dw_1.retrieve()

⑤ 在w_main窗口的cb_4按钮的Clicked事件中添加如下代码

java 复制代码
close(parent)

⑥ 在开发界面左边的System Tree窗口中双击exampleapp应用对象,并在其Open事件中添加如下代码

java 复制代码
SQLCA.DBMS = "O90 Oracle9i (9.0.1)"
SQLCA.LogPass = "tiger"
SQLCA.ServerName = "127.0.0.1:1521/orcl"
SQLCA.LogId = "scott"
SQLCA.AutoCommit = False
SQLCA.DBParm = "PBCatalogOwner='scott'"

connect;
open(w_main)

⑦ 在开发界面左边的System Tree窗口中双击exampleapp应用对象,并在其close事件中添加如下代码

java 复制代码
disconnect;

六、运行程序

运行程序,看看是否达到预期效果

相关推荐
七夜zippoe3 小时前
压缩与缓存调优实战指南:从0到1根治性能瓶颈(六)
1024程序员节
Web3_Daisy3 小时前
冷换仓的隐性代价:从安全策略到地址信誉体系的重新思考
大数据·安全·web3·区块链·比特币·1024程序员节
狡猾大先生3 小时前
ESP32S3-Cam实践(OLED表情动画-手搓)
笔记·1024程序员节
lpfasd1233 小时前
第三章-Tomcat请求处理原理
1024程序员节
m0_748233643 小时前
单调队列【C/C++】
c语言·c++·算法·1024程序员节
lpfasd1233 小时前
第八章-Tomcat调试与监控
1024程序员节
程高兴3 小时前
光储微电网离网+并网MATLAB仿真模型
1024程序员节
小小的木头人3 小时前
Redis 集群安装指南
数据库·redis
星空的资源小屋3 小时前
Antares SQL,一款跨平台开源 SQL 客户端
数据库·人工智能·pdf·开源·电脑·excel·1024程序员节