【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;

六、运行程序

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

相关推荐
谅望者1 小时前
数据分析笔记07:Python编程语言介绍
大数据·数据库·笔记·python·数据挖掘·数据分析
面向星辰1 小时前
sql基本增删改查语句汇总
数据库·sql·mybatis
一氧化二氢.h2 小时前
MySQL root用户连接错误解决方法
android·数据库·mysql
q***23922 小时前
数据库操作与数据管理——Rust 与 SQLite 的集成
数据库·rust·sqlite
q***33372 小时前
给SQL server数据库表字段添加注释SQL,附修改、删除注释SQL及演示
数据库·sql·oracle
百***22122 小时前
mysql 迁移达梦数据库出现的 sql 语法问题 以及迁移方案
数据库·sql·mysql
_Jimmy_2 小时前
ShardingSphere-JDBC 实现两个mysql数据库的不同表的关联查询
数据库·mysql
weixin_307779133 小时前
基于AWS的应用程序可靠性提升架构优化方案——RDS多可用区与EC2弹性架构实践
数据库·数据仓库·架构·云计算·aws
Chan163 小时前
【 Java八股文面试 | Redis篇 缓存问题、持久化、分布式锁 】
java·数据库·redis·后端·spring·缓存·面试
G***T6913 小时前
PostgreSQL全文搜索教程,中文分词配置
数据库·postgresql·中文分词