动态创建datawindow

li_d_s 2003-01-27 02:16:24
如何动态创建一个外部数据源的datawindow?需要例子
...全文
153 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
let5flying 2003-08-26
  • 打赏
  • 举报
回复
to kalven_chan(钱 钱)
十分感谢~~~~~~~~
QQQPPP 2003-02-16
  • 打赏
  • 举报
回复
同意 tchatcha(老刀) (
one_bird 2003-02-05
  • 打赏
  • 举报
回复
同意楼上
tchatcha 2003-01-28
  • 打赏
  • 举报
回复
动态数据窗口创建依据的是数据窗口语法,一般过程如下例所示:

// error_1用来存放SyntaxFromSQL()调用时产生的错误信息
// error_2用来存放Create()调用时产生的错误信息
string error_1, error_2
// sql用来存放数据窗口的SQL Select语句
// syntax用来存放数据窗口的格式语法
string sql , syntax
sql = 'SELECT author_code ,name from auths WHERE sex=1'
syntax = SQLCA.SyntaxFromSQL(sql, 'Style(Type=Form)', error_1)
IF Len(error_1) > 0 THEN
Messagebox("错误信息",error_1)
ELSE
// 创建动态数据窗口对象
dw_1.Create(syntax, error_2)
IF Len(error_2) > 0 THEN
Messagebox("错误信息",error_2)
END IF
END IF
dw_1.SetTransObject(SQLCA)
dw_1.Retrieve()

  在使用SyntaxFromSQL()函数创建动态数据窗口语法时,必须为其定义数据窗口所需的SQL语法和数据窗口的表现风格。SyntaxFromSQL()函数是事务对象上的一个方法,在使用前,事务对象必须已经指向一个数据库。

  还有另外一种创建数据窗口语法的方法:采用LibraryExport()函数。该函数何以把一个已经存在的数据窗口对象装载到一个字符串中,这样,该语法可以在Create()函数中调用来产生动态数据窗口。

  当然,我们也可以用程序动态拼凑语法来创建动态数据窗口,但数据窗口语法是很复杂的,这会给编程带来很大难度。所幸的是,我们可以使用数据窗口语法生成器来创建这些语法。

szpqq 2003-01-27
  • 打赏
  • 举报
回复
小鬼,不能这样说话!!!!!!!!!!!!!!!!!!!!
kalven_chan 2003-01-27
  • 打赏
  • 举报
回复
不好意思。呵呵
li_d_s 2003-01-27
  • 打赏
  • 举报
回复
楼上的,拜托你以后看清楚题目再做回答
kalven_chan 2003-01-27
  • 打赏
  • 举报
回复
在一个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自己写,只是文件头和数据窗结束标记不同而已。

611

社区成员

发帖
与我相关
我的任务
社区描述
PowerBuilder DataWindow
社区管理员
  • DataWindow社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧