動態數據窗創建原理及實現作者:流方 主頁: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_errorls_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 ifend if二、由另一個數據窗的syntax來創建string ls_syntax,ls_errorls_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_retls_ret = char(13)+char(10) //回車鍵int li_filenumlong li_lengthli_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 iffileclose(li_filenum)if li_length = 0 then returnls_syntax = "release 5;"+ls_ret+ls_syntax //截掉ls_syntax中的數據部分,5.0以"sparse(names="dept_name?) "作為參考位置//6.0以html(作為參考位置long pos1,pos2pos1 = 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自己寫,只是文件頭和數據窗結束標記不同而已。