动态数据窗创建原理及实现

原创 2001年04月29日 00:59:00
动态数据窗创建原理及实现
作者:流方 主页:http://liulee.myrice.com
在实际应用中,经常需要根据用户需求来动态创建数据窗,一般方法是这样的。

在一个window中加入一个数据窗控件,如dw_new,但是该数据窗没有data object,(空白的)
就可以用以下语法来创建:
dw_new.create(ls_syntax,ls_error) // 创建语法,错误信息
ls_syntax可以用以下三种方法来形成:

一、动态由sql语法创建:

// 连接到pb的example数据库
string ls_sql,ls_syntax,ls_error
ls_syntax = 'select * from department'
ls_syntax = sqlca.SyntaxFromSQL(ls_sql,'style(type=grid)',ls_error)
if len(ls_error) >0 then
    messagebox('Error','SyntaxFromSQL Error:~r'+ls_error)
else
    dw_new.create(ls_syntax,ls_error)
        if len(ls_error) >0 then
            MessageBox("Error", "Create have these errors: ~r" + ls_error)
        else
            dw_new.settransobject(sqlca)
            dw_new.retrieve()
        end if
end if

二、由另一个数据窗的syntax来创建

string ls_syntax,ls_error
ls_syntax = dw_test.describe('datawindow.syntax')
dw_new.create(ls_syntax,ls_error)
if ls_error <> '' then
    messagebox('Create Error',ls_error)
else
    dw_new.settransobject(sqlca)
    dw_new.retrieve()
end if

三、读取psr文件来创建

样例
string ls_syntax,ls_error,ls_ret
ls_ret = char(13)+char(10) //回车键
int li_fileNum
long li_length
li_FileNum = FileOpen("efef.psr",Streammode!, read!, shared!, Replace!)

// 以下是pb5的代码
if li_filenum >0 then
    FileSeek(li_FileNum, 158, FromBeginning!)
    li_length = fileRead(li_filenum,ls_syntax)
end if
fileclose(li_filenum)
if li_length = 0 then return
ls_syntax = "release 5;"+ls_ret+ls_syntax 

//截掉ls_syntax中的数据部分,5.0以"sparse(names="dept_name?)  "作为参考位置
//6.0以html(作为参考位置

long  pos1,pos2
pos1 = pos(ls_syntax,'sparse(names="',1)
pos2 = pos(ls_syntax,'"',pos1 +16)
ls_syntax = left(ls_syntax,pos1) + mid(ls_syntax,pos1 +1,pos2 - pos1 +1)

dw_New.create(ls_syntax,ls_error)

if ls_error <> '' then
    messagebox('Create Error',ls_error)
else
    dw_new.settransobject(sqlca)
    dw_new.retrieve()
end if

//pb6,pb7的代码可以参照pb5自己写,只是文件头和数据窗结束标记不同而已。

PB datawindows 动态创建数据窗口

PB datawindows 动态创建数据窗口 分类: 专业技能工作积累2011-08-04 16:521376人阅读评论(0)收藏举报 powerbuildervariablesobjec...
  • tlammon
  • tlammon
  • 2015年02月02日 15:33
  • 1377

【PB】如何创建一个动态的数据窗口对象?

问:我想在程序运行中根据需要动态地建立一个数据窗口对象,该怎么做呢? 答:方法有四: 第一种方法:     在程序中用Describe()函数得到某个已经存在的数据窗口对象的源代码。如: ...
  • tlammon
  • tlammon
  • 2016年03月01日 13:16
  • 1815

Vue实现动态创建和删除数据

Vue实现动态创建和删除数据
  • fengshiying
  • fengshiying
  • 2017年08月04日 18:46
  • 1482

Java操作Word模板实现动态数据输出工具类

  • 2017年08月30日 15:28
  • 3KB
  • 下载

动态数据源实现spring

  • 2014年03月15日 16:24
  • 803B
  • 下载

带背景图动态数据曲线的研究与实现

  • 2012年08月04日 03:15
  • 197KB
  • 下载

JAVA操作WORD模板实现动态数据输出

  • 2011年09月08日 16:22
  • 531KB
  • 下载

关于数据库连接池和动态数据源的实现

  • 2015年07月30日 17:54
  • 336KB
  • 下载

Highcharts AJAX JSON JQuery 实现动态数据交互显示图表 柱形图

  • 2014年12月05日 16:57
  • 2KB
  • 下载

ava操作Word模板实现动态数据输出

  • 2012年04月01日 09:20
  • 709KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:动态数据窗创建原理及实现
举报原因:
原因补充:

(最多只允许输入30个字)