powerbuilder的数据窗口函数汇总

气有浩然,学无止境!数据库操作,无非增删改查!

1、SetTransObject( )

  • 作用

在使用数据窗口控件检索数据前,必须通知数据窗口使用哪个事务对象来操作数据库(实际上也就是告诉数据窗口从哪个数据库中检索数据)。一般来说,我们在数据窗口控件所在窗口的Open事件中执行SetTransObject()函数

  • 示例

数据窗口控件dw_1与连接数据库的事务对象SQLCA联系在一起。dw_1.SetTransObject (SQLCA)

2、Retrieve

  • 作用

调用数据窗口控件的对象函数Retrieve()把数据装入数据窗口

  • 示例

返回长整型ll_rows,代表检索出来的数据行数,返回值<1时返回错误提示

long ll_rows
dw_main.SetTransObject(SQLCA)
ll_rows = dw_main.Retrieve()
IF ll_rows < 1 THEN 
    MessageBox("Database Error","No rows retrieved.")
end if

3、InsertRow( )

  • 作用

在数据窗口的主缓冲区中插入一个空行

  • 示例

返回长整型的行号

long ll_newrow
ll_newrow = dw_employee.InsertRow(0)
dw_employee.ScrollToRow(ll_newrow) //当在数据窗口主缓冲区的末尾插入一行时,新行并不一定能在数据窗
                                   //中看到,这时可以使用函数ScrollToRow( )。

4、deleterow()

  • 作用

在数据窗口的主缓冲区(即显示在用户面前的数据中)中删除一行

  • 示例

通过getrow获取当前鼠标所在行号,然后deleterow删除,最后update更新数据库

int s
s = dw_1.getrow( ) //该函数返回一个long型值,表示当前行号。如果没有选中任一行,则返回0,出错时返回-1。
dw_1.deleterow( s)
dw_1.update( ) //更新数据库

5、SetSQLSelect()

  • 作用

详述sql select的查询状态

  • 示例一
string OldSyn, NewSyn

OldSyn = 'SELECT employee.EMP_Name FROM employee WHERE salary < 70000'

NewSyn = 'SELECT employee.EMP_Name FROM employee WHERE salary < 100000'

IF dw_emp.Retrieve( ) = 0 THEN
        dw_emp.SetSQLSelect(NewSyn)
        dw_emp.Retrieve()
END IF
  • 示例二

按照客户编号查询数据,sle_1.text为SigleEdit的窗口输入内容。

string wheresql,newsql
long lrc

if sle_1.text<>"" then
    wheresql="where 客户编号='"+sle_1.text+"'"  
    newsql=oldsql+wheresql  
    dw_1.setsqlselect(newsql)
    lrc=dw_1.retrieve( )
    //如果lrc<1说明没有检索到数据,给出一个提示框
    if lrc<1 then
        messagebox("提示","没有检索到,请检查客户编号")
    end if
else
    messagebox("提示","请输入客户代号")
end if

6、setfilter

每次setfilter、filter之后,只用setfilter("")即可,不用再filter,下次你retrieve时,由于setfilter("")了,所以是全数数据。示例如下:

dw_1.settransobject(sqlca)
dw_1.retrieve()
dw_1.setfilter("")
if rb_1.checked then
    dw_1.setfilter("(图书编号 like '%"+sle_1.text+"%')")
elseif rb_2.checked then
    dw_1.setfilter("(书名 like '%"+sle_1.text+"%')")
elseif rb_3.checked then
    dw_1.setfilter("(作者 like '%"+sle_1.text+"%')")
elseif rb_4.checked then
    dw_1.setfilter("(出版社 like '%"+sle_1.text+"%')")
end if

dw_1.filter( )

数据窗口四大数据缓冲区:

1、Primary Buffer

这个缓冲区是存放填充窗口中DataWindow控件中数据的,调用DataWindow的Retrieve()函数和InsertRow()函数可以将数据填入这个缓冲区中。当使用有关DataWindow删除和过滤函数时,相应记录将从这一缓冲区中删除。而在执行DataWindow的Update()函数时,PowerBuilder将查看这一缓冲区中的记录,以形成SQL INSERT和UPDATE语句。

2、Delete Buffer

这个缓冲区保存的是用DeleteRow()函数从Primary Buffer中删除的记录,执行Update()函数时,系统根据这一缓冲区的记录形成DELETE语句。

3、Filter Buffer

这个缓冲区存储的是从Original Buffer使用Filter()函数过滤到Primary Buffer中后剩余的记录。

4、Original Buffer

这一缓冲区存储的是DataWindow最初执行retrieve()函数时得到的全部记录。当提交数据库时,根据Primary Buffer生成的UPDATE语句和根据Delete Buffer生成的DELETE语句都要依据这一缓冲区来构造这些SQL语句中的Where子句。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • Windows 常用消息大全 表A-1 Windows消息分布 消息范围说 明 0 ~ WM_USER – 1系统...
    北风知我意阅读 2,040评论 0 0
  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 5,507评论 0 4
  • 翩翩落叶片片愁, 丝丝小雨处处忧; 才道世间无独守, 怎料江上一偏舟?
    费马不是马阅读 182评论 0 0
  • 我没有吃过鱼松饭,看到剧中的鱼松饭好想吃! ...
    小英025阅读 475评论 0 2
  • 朋友甩给我一张图 说推荐我画 只能说技术有限 这个……有点小孩子气了 也不知道是什么树 原图很美,再看看我画的……...
    乔伊乔一阅读 167评论 0 6