明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

在powerbuilder中使下拉下文框可以與數(shù)據(jù)關(guān)聯(lián)

[摘要]在從事使用powerbuilder進(jìn)行數(shù)據(jù)庫(kù)開發(fā)的過(guò)程中,常常碰到要使用列表框來(lái)選擇數(shù)據(jù),但是普通的下拉列表框并沒有提供和數(shù)據(jù)相連接的方法,而使用數(shù)據(jù)窗口的子下拉列表框來(lái)代替又顯得有些別扭.下面介紹一種好看又好用的方法.  可能大家已經(jīng)想到了吧,使用指針把要連接的數(shù)據(jù)一條一條地從select 語(yǔ)句...
在從事使用powerbuilder進(jìn)行數(shù)據(jù)庫(kù)開發(fā)的過(guò)程中,常常碰到要使用列表框來(lái)選擇數(shù)據(jù),但是普通的下拉列表框并沒有提供和數(shù)據(jù)相連接的方法,而使用數(shù)據(jù)窗口的子下拉列表框來(lái)代替又顯得有些別扭.下面介紹一種好看又好用的方法.
  可能大家已經(jīng)想到了吧,使用指針把要連接的數(shù)據(jù)一條一條地從select 語(yǔ)句的查詢結(jié)果中fetch 出來(lái),然后再把數(shù)據(jù)additem到下拉列表框中去.
  雖然這也是一種可行的方法,但是他的速度很不能令人滿意,太受數(shù)據(jù)量的影響.
  我們可以利用powerbuilder 最推崇的數(shù)據(jù)窗口技術(shù)作為數(shù)據(jù)庫(kù)和下拉列表框連接的橋梁,這種方法即方便快速又安全可靠.
好了,下面制作的下拉列表框,在完成之后會(huì)帶給你許多意想不到的方便!

一. 打開powerbuilder的"select user object"畫筆,選擇<new>, 在"new user object"中選擇"Visual"類的"Standard"項(xiàng)并按下<ok>, 在彈出來(lái)的"Select Standard Visual Type"對(duì)話框中選擇列表中的 "dropdownlistbox"項(xiàng)并按下<ok>. 接著加入一些實(shí)例變量,選擇"Declare"菜單項(xiàng)的"Instance Variables.."
加入變量的聲明: datastore ids_user int il_row 并按下<ok>.
我們要對(duì)新的對(duì)象進(jìn)行一些限制,在對(duì)象的"constructor"事件中加入 程序:
sorted = false //這句非常必要
reset()

二. 好了,現(xiàn)在到了最關(guān)鍵的時(shí)候了,我們要把數(shù)據(jù)檢索出來(lái)放到ids_user
變量里.
選擇菜單"Declare"項(xiàng)的"User Object Function",在彈出來(lái)的對(duì)話框
中按下<new>新建一個(gè)對(duì)象函數(shù)命名為:
init
參數(shù)有一個(gè):
sqlstr string
返回值為整型:integer
現(xiàn)在我們需要?jiǎng)討B(tài)地創(chuàng)建datastore
在init函數(shù)中寫下:
//integer init(sqlstr string) 開始
long ll_rowcount
long ll_row
string ls_sql
string errors
string ls_return
ids_user = create datastore
//根據(jù)sql語(yǔ)句產(chǎn)生數(shù)據(jù)窗口
ls_return = sqlca.SyntaxFromSQL(sqlstr, 'style(type=grid)',errors)
//sql語(yǔ)句有錯(cuò)誤
if len(errors) > 0 then
messagebox('錯(cuò)誤', errors)
return -1
end if
//根據(jù)語(yǔ)法動(dòng)態(tài)創(chuàng)建數(shù)據(jù)窗口
ids_user.create(ls_return)
ids_user.settransobject(sqlca)
ll_rowcount = ids_user.retrieve()
//無(wú)數(shù)據(jù)返回
if ll_rowcount=0 then
return -1
end if
//把數(shù)據(jù)插入控件
for ll_row = 1 to ll_rowcount
this.additem(string(ids_user.Object.Data[ll_row,1]))
next
//成功返回0
return 0
//integer init(sqlstr string) 結(jié)束

現(xiàn)在下拉列表框已經(jīng)能顯示數(shù)據(jù)了,但是我們?cè)谶x擇數(shù)據(jù)的同時(shí)往往
需要的不是它顯示出來(lái)的值,比如顯示的是人員姓名,而我們需要的
是工號(hào),難道再使用select語(yǔ)句把需要的數(shù)據(jù)檢索出來(lái)嗎?有了下面的
程序,我們就不必頭痛了.
重復(fù)上面建立函數(shù)的步驟,新建一個(gè)名為getdata的user object函數(shù),
返回值為"any"并在函數(shù)中寫下程序:
//any getdata() 開始
any la_return
long ll_row
if text = '' then
return ''
end if
//沒有選擇或沒有檢索到數(shù)據(jù)
if ids_user.rowcount() = 0 or il_row = 0 then
return ''
end if
//在缺省情況下返回第二列的數(shù)據(jù)
la_return = ids_user.Object.data[il_row, 2]
return la_return
//andy getdata() 結(jié)束

現(xiàn)在還不能返回正確的數(shù)據(jù),還需要一個(gè)函數(shù)setidx(idx int)
程序如下:
//setidx(idx int) 開始
il_row = idx
//setidx(idx int) 結(jié)束

現(xiàn)在這個(gè)user object已經(jīng)完成了,我們來(lái)做一下試驗(yàn)試一試.
新建一個(gè)應(yīng)用app_test,一個(gè)窗口w_main,按照剛才的方法創(chuàng)
建一個(gè)user object:uo_dbdropdownlistbox,放入w_main中
在app_test的open事件中寫下連接數(shù)據(jù)庫(kù)的語(yǔ)句并加上open(w_main)
在w_main的open事件中寫下:
int li_result
li_result = uo_1.init('select name, id from sysobjects')
在uo_1的selectionchanged事件中寫下:
setidx(index)
messagebox('提示', "看" + string(this.getdata()))
這時(shí)我們的用戶對(duì)象已經(jīng)能根據(jù)選擇的name返回相應(yīng)的id了.
至于更多的功能,還有待powerbuilder的愛好者們不斷地思考
創(chuàng)造了.如果還想深入討論請(qǐng)和我聯(lián)系:fly-back@163.com