PB数据窗口中的几种状态及应用
数据窗口的状态主要有以下几种:
1)New!
2)NewModified!
3)DataModified!
4)NotModified!
数据窗口可以利用这些状态标志判断数据是否被修改过。
记录和字段的状态标志如下:
××××××××××××××××××××
状态 使用范围
NotModified! 记录与字段
DataModified! 记录与字段
New! 记录
NewModified! 记录
×××××××××××××××××××××××
当第一次使用retrieve()函数从数据库中读取数据时,所有在数据窗口缓冲区的记录与字段都是属于NotModified!状态。
当时数据被修改过后,被修改过的记录状态标志与字段状态标志都会被改成DataModified!
当增加一笔数据时,增加数据的字段状态标志为NotModified!,记录状态标志为New!.
当我们在增加的字段中填上数据后,字段状态标志为DataModified!记录状态标志为NewModified!
二、状态的获取及设置
dw_1.getitemstatus(dw_1.getrow(),0,primary!)
dw_1.setitemstatus(dw_1.getrow(),0,primary!,DataModified!)
三、状态的一些应用
1)新增数据时,不提交更新
在PB中,通常我们给用户提供了新增的功能,这样用户每点击一次,就会新增一行;而在新增的时候,根据业务需求,我们会对一些列赋值。
但是,用户也可能是多点击了新增按钮,就会出现有些数据实际上是并不需要更新到数据库的。
这个时候,就需要程序来循环删除或者让用户手工删除。
而如果,我们在触发新增动作时,就把这条记录的状态更改了,改为NotModified!的话,在数据窗口提交更新的时候,就不会将这些记录提交到数据库了;而我们也不用再去删除数据了。
2)数据修改时,不提交更新
有时,我们为了满足用户的需求,在某一列上会根据需要而显示不同的值。虽然我们只是给用户提供的显示内容,实际上是并不需要更新数据库中的内容的。但是数据窗口本身的状态会改变,这样在提交更新的时候,就会将这些值更新到数据库中。
如果不考虑状态控制的话,我们还需要根据情况,对这些数据做些处理,以还原成检索出来的值。
如果用状态的话,则非常简单,只需要在触发显示不同值的地方,将其状态更改为 NotModified!即可。
3)数据修改时,不覆盖原数据,而是新增记录
当我们修改了原数据时,又不希望覆盖原数据,而是想要新增一条记录,这时,我们可以把原数据的记录状态改为NewModified!
----
1、 getitemstatus(row,column,dwbuffer)注:如想得到整行的状态,column参数设为0。
2、先删除当前行,再rowcopy。
---------------------------------------------------------------
1. GetItemStatus ( long row, integer column, DWBuffer dwbuffer ) 2. dw_2.Object.Data {.buffer } {.datasource } [ startrownum,
startcolnum, endrownum, endcolnum ] = dw_1.Object.Data {.buffer } {.datasource } [ startrownum,
startcolnum, endrownum, endcolnum ] (可以一试)
---------------------------------------------------------------
补充:getitemstatus返回值为dwItemStatus枚举类型,取值为:datamodified!,new!,newmodified!,notmodified!.
---------------------------------------------------------------
---------------------------------------------------------------
choose case dw_1.getitemstatus(1,0,primary!) case datamodified!
messagebox('','修改') case new! messagebox('','新行')
case newmodified! messagebox('','新行已修改') case notmodified!
messagebox('','什么都没干') end choose
---------------------------------------------------------------
PB数据窗口中的几种状态及应用的更多相关文章
- pb数据窗口设置操作
1 使DataWindow列只能追加不能修改如何使DataWindow中的数据只能追加新记录而不能修改,利用 Column 的 Protect 属性可以很方便的做到这一点,方法如下:将每一列的 Pro ...
- java对象中的三种状态和脏检查及刷新缓存机制
瞬时状态 瞬时状态又称临时状态.如果java对象与数据库中的数据没有任何的关联,即此java对象在数据库中没有相关联的记录,此时java对象的状态为瞬时状态,session对于 瞬时状态的ava对象是 ...
- Egret 中实现3种状态切换按钮
一.游戏中的常用3种状态按钮 Egret种提供了2种状态切换的按钮ToggleButton. 但是在游戏中常用到3种状态的按钮,比如任务系统的领取.已领取.未领取. 比如下图中宝箱的打开.浏览后打开. ...
- powerbulider9.0在数据窗口中实现滚动到新添加行
powerbuilder9.0对数据窗口进行增加行操作,然后实现滚动到指定行时,应先滚动到指定行dw_1.scrolltorow( row),然后设置新添加的行为当前行dw_1.setrow( row ...
- WPF中CheckBox三种状态打勾打叉和滑动效果
本文分为两个demo, 第一个demo实现checkBox的打叉或打勾的效果: 第二个demo部分实现checkBox的滑动效果. Demo1: wpf的CheckBox支持三种状态,但是美中不足的是 ...
- 01-08-01【Nhibernate (版本3.3.1.4000) 出入江湖】NHibernate中的三种状态
以下属于不明来源资料: 引入 在程序运行过程中使用对象的方式对数据库进行操作,这必然会产生一系列的持久化类的实例对象.这些对象可能是刚刚创建并准备存储的,也可能是从数据库中查询的,为了区分这些对象,根 ...
- 使用flask框架实现web页面与数据库数据互联+常见的几种状态码
1.通过cygwin从pip install两个包:PyMySQL.SQLAlchemy: 2.在app.py中import我们要用到的库中的包:create_engine,text :from sq ...
- pb数据窗口之间的传参
问题描述: 通过一个窗口打开一个子窗口并传递指定参数查询详细信息 解决方法: 在前者窗体的user object下的itemchanged事件中,相应位置加入openwithparm函数 : op ...
- ASP.Net中的四种状态保持机制
每个人上网可多有过这样的情况,当我们登陆某个网站时,在登陆的旁边会有一个 "记住我" 的复选框,有的网站还会让用户选择记住我.这个记住我是怎么实现的呢? 其实就用利用的是cooki ...
随机推荐
- vue 城市列表与字母表联动
实现两个联动 一是点击右侧字母的时候,城市列表出现相应首字母下的城市 二是鼠标在字母表上滑动的时候,城市列表实时跟着变化 一.点击字母出现相应的列表,给每个字母设置handleLetterClick事 ...
- 路由器基础配置之rip
我们将以上面的拓扑图进行实验,用rip协议来进行实验,目的是实现三台不同网段的pc机之间实现互相通信 首先为pc机配置好ip地址和网关,配置完IP地址后在配置路由器 router1: enable 进 ...
- java 计算数学表达式及执行脚本语言
java SE6中对常用的脚本语言做了支持. 可供使用者在java代码中执行脚本语言,还可以利用get("key"),put("key","value ...
- kickstart+pxe+tftp+ntp(http)自动化安装平台的搭建
听说过"克隆"吗,对于这个科技术语20年前可能还很陌生,羊可以克隆,通过基因dna序列:机器同样可以克隆通过网络IP! 如下为自动化安装平台: PXE(preboot execut ...
- 平衡二叉查找树 AVL 的实现
不同结构的二叉查找树,查找效率有很大的不同(单支树结构的查找效率退化成了顺序查找).如何解决这个问题呢?关键在于如何最大限度的减小树的深度.正是基于这个想法,平衡二叉树出现了. 平衡二叉树的定义 (A ...
- 【Python 2 到 3 系列】 print 是函数
v3.0 以前,print一直作为语法结构存在,他是python语法的一部分:这个理解起来可能有点蹩脚,但的确是这样. print 一直被定以为一个statement,也就是说,他跟return/tr ...
- 谷歌浏览器如何调试JS
平常在开发过程中,经常会接触到前端页面.那么对于js的调试那可是家常便饭,谷歌浏览器是常用来调试JS代码的工具,本文主要介绍如何利用谷歌浏览器来调试JS代码,协助我们进行开发工作,加快开发效率. 1. ...
- 数据分析处理库Pandas——数据透视表
数据 按指定的行列值显示 求和 按行求和 按列求和 数据 求平均 备注:按性别计算每个等级船票的平均价格. 备注:每个等级船舱中每种性别获救的平均值,也就是获救的比例. 备注:每种性别未成年人获救的平 ...
- 【Sklearn系列】使用Sklearn进行数据预处理
这篇文章主要讲解使用Sklearn进行数据预处理,我们使用Kaggle中泰坦尼克号事件的数据作为样本. 读取数据并创建数据表格,查看数据相关信息 import pandas as pd import ...
- openwrt(二) 配置openwrt及编译
导航 1. 配置openwrt 2. 编译openwrt 3. 错误记录 1. 配置openwrt 在openwrt的根目录下,执行make menuconfig. 这个界面我也只是了解了这两个选项而 ...